服务器调数据卡顿?
500
2024-04-27
微信官方没有JAVA通用版。微信版本:iOS版、Android版、MAC版、微信电脑插件版(Windows 、Windouws phone 7、Windouws phone 8)、symbian版、BlackBerry版、BlackBerry 10版、series 40版。
微信小程序作为一种轻量级的应用程序,一直受到开发者和用户的青睐。随着移动互联网的快速发展,微信小程序在各行各业广泛应用,为用户提供了便捷的服务体验,同时也为企业和个人带来了更多商机。在微信小程序的发展过程中,环信作为一家专注于即时通讯领域的企业,在小程序中也发挥了重要的作用。
微信小程序作为微信生态的一部分,具有快速启动、无需安装、占用空间小等优势,为用户提供了便捷的应用体验。而环信作为一家专业的通讯解决方案提供商,拥有稳定可靠的即时通讯技术,为手机应用程序集成实时消息推送、聊天、语音视频通话等功能,为用户提供了多样化的通讯工具。
近年来,微信小程序与环信的合作案例不断涌现。以在线教育行业为例,许多在线教育机构利用微信小程序开展课程推广、报名管理等工作,而环信的即时通讯技术则为学生和老师提供了高效的沟通平台,极大地提升了在线教育的教学效率。在电商领域,微信小程序可以实现商品展示、下单购买等功能,而环信的消息推送功能可以帮助商家及时推送促销信息,吸引更多用户参与购买。
随着移动互联网的不断发展,微信小程序与环信在通讯与互动领域的合作空间也在不断拓展。未来,可以预见的是,微信小程序将更多地融入生活的方方面面,为用户提供更为丰富多彩的应用体验,而环信的通讯技术也将继续发挥着重要的作用,提升用户之间的沟通效率。
综上所述,微信小程序与环信的结合,不仅为用户带来了便捷、高效的通讯体验,同时也为企业和个人的发展带来了更多的机遇。期待未来,微信小程序与环信的合作会在更多领域展开,为用户创造更加丰富多彩的移动互联网世界。
这个没什么问题吧,创建多个客户端对象就行了,不知道你用的那种客户端对象。 只是注意如果绑定IP地址和端口,那么本地的IP地址和端口不能重复。 就是说多个客户端要么IP不同,要么使用的端口不同。
在如今信息爆炸的时代,群聊已经成为人们日常生活中不可或缺的一部分。无论是工作需求还是社交娱乐,群聊都扮演着重要的角色。而对于开发者来说,如何实现一个稳定高效的群聊功能成为了一个挑战。今天我们就来讨论如何运用环信结合PHP来实现群聊功能。
环信是一个强大的即时通讯云服务提供商,为开发者提供了丰富的即时通讯功能组件和解决方案。无论是单聊、群聊、还是实时音视频通话,环信都能满足开发者的各种需求,帮助开发者快速搭建起稳定可靠的即时通讯应用。
PHP作为一种流行的服务器端脚本语言,广泛应用于Web开发领域。在群聊中,PHP可以用来处理用户请求、与数据库交互、数据处理等功能。结合环信的即时通讯功能,我们可以通过调用环信提供的API来实现群聊功能的快速开发。
首先,我们需要在环信官网上注册账号,并创建一个应用用于集成群聊功能。在创建应用后,环信会为我们分配一个唯一的AppKey和AppSecret,在后续的集成过程中会用到这些信息。
接下来,在我们的PHP项目中引入环信的SDK,并通过Composer进行安装。在安装完成后,我们需要进行SDK的初始化配置,填入我们在环信官网上获得的AppKey和AppSecret。
然后,我们可以通过环信提供的API来创建群组、添加成员、发送消息等操作。通过调用相应的API接口,我们可以实现群聊功能所需的各种操作,包括创建群组、邀请成员、发送消息、获取历史消息等。
在群聊功能开发过程中,我们还可以根据具体需求进行二次开发,比如实现@提醒功能、消息撤回功能、消息加密等。这些功能的实现可以通过PHP结合环信提供的API来实现。
为了提升群聊功能的体验,我们可以结合前端技术实现消息即时展示、图片视频预览、消息撤回确认等功能。同时,我们也可以使用环信提供的Web SDK来实现Web端的即时通讯功能,进一步丰富群聊的交互方式。
此外,为了保障群聊功能的稳定性和可靠性,我们还可以进行服务器集群部署、消息日志记录、异常处理等操作。通过这些措施,可以有效提升群聊功能的使用体验,保证用户能够顺畅地进行群聊交流。
通过环信结合PHP,我们可以快速实现稳定高效的群聊功能。在开发过程中,我们需要熟悉环信提供的API接口,结合PHP的特性进行开发,同时注意优化用户体验和保障功能稳定性。希望以上内容能够帮助开发者更好地实现群聊功能,提升应用的交互体验。
环信是一家专注于即时通讯领域的技术公司,提供一系列强大的即时通讯解决方案,极大地方便了开发人员在应用中集成实时聊天功能。而在网站开发中,结合php作为后端编程语言,实现与环信即时通讯技术的结合,不仅能够为用户带来更加丰富的互动体验,也能为网站运营者提供更多的增值服务。
作为一家专业的即时通讯服务提供商,环信拥有许多优势,为开发者和企业提供了全面的支持。首先,环信提供的SDK和API非常易于集成,无论是在移动端还是Web端,开发者都可以快速地将即时通讯功能整合到自己的应用中。其次,环信拥有强大的消息推送服务,可以确保消息的实时性和稳定性,让用户能够及时收到重要信息。此外,环信还提供了丰富的扩展功能,比如群聊、消息撤回、消息漫游等,满足不同场景下的业务需求。
在网站开发中,php是一种常用的后端编程语言,具有广泛的应用。结合php和环信的即时通讯技术,可以为网站添加丰富的实时互动功能,提升用户体验和网站的吸引力。通过php后端处理业务逻辑,再结合环信的SDK,可以实现用户之间的即时通讯、消息推送等功能,为用户提供更加便捷的沟通方式。
同时,php的灵活性和兼容性使得与环信的集成更加容易。开发者可以利用php强大的后端处理能力,结合环信高效稳定的即时通讯服务,打造出更加完善的网站应用。无论是电商网站、社交平台还是在线教育平台,都可以通过结合php和环信的技术优势,为用户提供全新的互动体验。
在实际开发中,将php与环信集成起来并不复杂。首先,开发者需要注册环信账号,获取相应的AppKey和AppSecret等信息。然后,在php后端代码中,引入环信提供的SDK,并进行初始化配置,包括AppKey和AppSecret等参数的设置。接着,开发者可以根据业务需求,调用环信提供的API,实现即时通讯功能,比如发送消息、创建群组等操作。
通过php的后端支持,开发者可以对用户的行为进行更加灵活的处理,比如权限控制、数据处理等。结合php的强大功能和环信的即时通讯服务,可以为网站开发者提供更多的可能性,打造出更具竞争力的网站产品。
环信作为即时通讯领域的领军企业,为开发者提供了强大的即时通讯解决方案,助力他们构建用户友好的应用。而结合php作为后端编程语言,可以为网站注入更多的实时互动功能,丰富用户体验,提升网站的价值。未来,随着互联网的不断发展,php与环信的结合将会在更多领域展现出强大的应用价值。
在编写网络应用程序时,经常会遇到需要在 Java 中向服务器端发送消息的情况。这种需求可能来自于用户交互、实时更新或其他需要与服务器进行通信的功能。如何高效地实现在 Java 中向服务器发送消息是开发人员需要思考和解决的关键问题之一。
在 Java 中,有多种方式可以实现向服务器发送消息的功能。其中,常用的方法包括使用 HttpUrlConnection、Apache HttpClient 或 Spring RestTemplate 等工具库来建立与服务器的连接并发送请求。这些工具库提供了丰富的功能和API,能够满足不同场景下的需求。
HttpUrlConnection 是 Java 标准库提供的一个用于发送 HTTP 请求和接收 HTTP 响应的类。通过使用 HttpUrlConnection,开发人员可以轻松地建立与服务器的连接,并发送 GET、POST 等不同类型的请求。以下是一个简单的使用示例:
public void sendGetRequest() {
try {
URL url = new URL("e.com/api/resource");
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setRequestMethod("GET");
BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
String line;
StringBuffer response = new StringBuffer();
while ((line = reader.readLine()) != null) {
response.append(line);
}
reader.close();
System.out.println(response.toString());
connection.disconnect();
} catch (IOException e) {
e.printStackTrace();
}
}
Apache HttpClient 是 Apache 软件基金会提供的一个功能强大的 HTTP 客户端库,用于处理 HTTP 请求和响应。与 HttpUrlConnection 相比,Apache HttpClient 提供了更丰富的功能和更便捷的 API,使得向服务器发送消息变得更加灵活和高效。
Spring RestTemplate 是 Spring 框架提供的一个用于处理 RESTful 服务的模板类。通过 Spring RestTemplate,开发人员可以方便地发送各种类型的 HTTP 请求,并处理服务器返回的响应数据。在基于 Spring 框架开发的应用程序中,RestTemplate 是一个非常常用的类库。
无论是使用原生的 HttpUrlConnection,还是第三方库如 Apache HttpClient 或 Spring RestTemplate,在实现消息发送功能时,都需要遵循一些最佳实践,以确保代码质量和系统稳定性。
在 Java 中想服务器端发送消息是开发中常见的需求,通过选择合适的消息发送方式和遵循最佳实践,可以保证消息发送的稳定性、可靠性和性能表现。无论是简单的 GET 请求还是复杂的 POST 请求,开发人员都可以根据实际场景选择适合的工具库,并根据需求进行定制化开发,以实现高效的消息传递。
在开发Web应用程序时,文件上传是一个常见的功能需求。无论是用户上传头像、文档,还是其他类型的文件,都需要在服务器端进行处理。而对于使用Java语言开发的应用程序,将文件上传到Linux服务器端是一个常见的情况。本文将探讨如何在Java应用程序中实现文件上传到Linux服务器的最佳实践。
1. 使用Apache Commons FileUpload
Apache Commons FileUpload 是一个流行的开源库,用于处理文件上传功能。通过引入该库,可以简化Java应用程序中处理文件上传的过程。首先,您需要在项目中添加对该库的依赖。然后,可以使用其中提供的类来处理文件上传的逻辑。在处理文件上传时,确保设置合适的文件大小限制、文件类型限制等,以提高安全性。
2. 配置Linux服务器端环境
在将文件上传到Linux服务器端之前,需要确保服务器端环境已经做好了相应的配置。首先,确保目标目录有足够的写入权限,以便接收上传的文件。其次,考虑使用安全的传输协议,如SFTP,以加强文件传输的安全性。另外,及时清理服务器上的无用文件,以释放存储空间。
3. 使用SSH进行文件传输
在Java程序中实现文件上传到Linux服务器端时,可以考虑使用SSH协议进行文件传输。SSH是一种安全的远程登录协议,可以通过Java程序来调用SSH命令实现文件的上传。通过建立安全的SSH连接,可以确保文件传输的安全性和稳定性。
4. 实现断点续传功能
对于大文件的上传,断点续传是一个非常重要的功能。通过实现断点续传,可以在文件上传过程中出现意外中断时,能够从中断处继续上传,而不用重新上传整个文件。考虑在Java应用程序中实现断点续传功能,以提高用户体验和文件上传的效率。
5. 异步文件上传处理
为了提高系统的性能和响应速度,可以考虑使用异步文件上传处理。通过在Java应用程序中引入异步处理机制,可以将文件上传操作放入后台线程中进行处理,从而不会阻塞主线程。这样可以提高系统的并发能力和性能表现。
6. 日志记录和错误处理
在文件上传过程中,及时记录日志信息是非常有必要的。通过记录上传日志,可以方便后续对文件上传情况进行监控和追踪。另外,合理处理文件上传过程中可能出现的错误和异常情况,保证系统的稳定性和可靠性。
7. 测试和优化
最后,在实现文件上传到Linux服务器端的功能后,务必进行全面的测试和优化。通过模拟不同的上传场景,测试文件上传的性能和稳定性。根据测试结果,进行必要的优化和调整,以确保文件上传功能能够在不同条件下正常运行。
文件上传功能是Web应用程序中一项重要而常见的需求。通过遵循最佳实践、合理配置服务器环境、使用安全的传输协议以及进行充分的测试,可以保证文件上传到Linux服务器端的顺利进行。希望本文介绍的内容对您在Java开发中实现文件上传功能有所帮助。
经历过和题主一样的纠结、选择,最终我选了 C++
选择那一门语言对学习linux服务器端编程最有帮助?
毫无疑问,C++!
学C++,其实约等于掌握了 C + C++,并且后续掌握 Java 也会很快,毕竟C++学习曲线会陡一些。
单独学 C可能很难找到互联网相关工作。
为什么我推荐 C++?
因为你想学习 Linux 服务端编程,那么选择 Linux C++ 就是最好的方式。
我本来大二一直都在学Java的,后来大二下开始转 Linux C++,在校招中也顺利拿到了腾讯微信后台 C++ offer,所以我相信我的路线一定对你或者后来的学弟学妹们有帮助!
这样的学习路线相信大家都见得不少了,写之前也非常忐忑,能不能和其它人写得不一样, 也定下了一个目标,在这里,不能是简单的堆砌学习资源和书单推荐,更要细化如何有效的去执行落地。
争取做到让看到的同学有一种相见恨晚的感觉哈哈哈。
所以大家可以试着看一下,帮我检查下有没有达到预想的效果哈哈,希望不要被打脸
那就正式开始吧。
(学习路线有点长,先给大家一波我的面经、看的书、刷题笔记等汇总:
绝不是在网上那种打包下载的,而是自己需要学到某个方向知识的时候,需要看了,去网上挨个找的,最后汇总而成。这部分我是会不断把它完善的,当成自己的小电子书库,不多,但贵在精。
我整理的这些书大家可以在这里获取,对于学习计算机的同学帮助非常大,且十分系统:
下载链接:
计算机必看经典书单经常在各大公司招聘上看到后端、后台、服务器开发等等,有些同学经常被这些名词搞混。
其实这些名词都是相近的,但是也有点区别,这里说说我的理解:
后台一般和后端是一个意思,而服务器开发则稍微广义一点,不仅包含了后台开发,而且也包括支撑整个后台应用的基础开发,比如搜索引擎、微服务、RPC 框架、KV、存储、MQ 等。
后台/后端重在业务处理,是偏向应用层开发,而服务器开发不仅包括应用层开发,更是囊括了整个支撑后台业务的相关组件的开发。
那 Linux C/C++ 服务器/后台开发指的什么呢,其实就是基于 Linux 上 的 C++ 编程。
但是相比 Java 系更强调 Linux 系统编程、网络编程能力,有的还会涉及到服务端底层协议和网络框架开发。
传统的 Java 、Go后台开发偏向 Web 开发,也就是接收前端请求,通过微服务互相调用,完成业务逻辑处理,然后返回给前端。
实际上在腾讯这边的 C++ 后台开发,也是类似的,本身有非常成熟的基于 C++ 的微服务体系,大多数开发也只需要关注业务逻辑就好,不过还是会要求 Linux 系统编程、网络编程等能力。
一般来说 Linux C/C++ 后台开发方向涉及以下这些基础知识:
非必选加分项:
由于篇幅限制,这篇文章主要介绍基础知识的学习路线和方法,其它加分项以后再单独写。
首先是语言的基础知识,一些关键字和实现原理等:
这里列出来的只是一些比较重要的部分,实际上可能只算 C++ 的冰山一角, 大家且学且珍惜吧,这不 C++11 还没整透彻,C++ 20 又出来了,生命不息,学习不止。
怎么学?
1. 《C++ Primer》
这本书基本包括了 C++ 11 的全部特性,最好把前面三部分:C++基础、C++标准库、类设计者的工具都看一遍,我当时花了一个多月断断续续看到了第16章模板那里。
2. Effective 系列:《Effective C++》、《More Effective C++》、《Effective STL》
第一本是重点,光看《C++ Primer》缺少实践的话,大概率还写不出合格的 C++ 代码,而《Effective C++》就是通过 55 条非常具体的做法告诉你什么样才是符合 C++ 编码规范的,可以缩短你写出合格 C++ 代码的时间,减少踩坑,强烈推荐必读,后面两本优先级稍低,可以有时间再读。
3. 《STL 源码剖析》和《深度探索 C++ 对象模型》
看完 Primer 和 Effective,你应该已经能够比较熟练的使用C++了,但是还缺少对 C++ 底层实现机制的认识。比如虚函数表、成员变量布局等,同时对于 STL 库可能也仅仅停留在使用上。 推荐的这两本可以分别完善你在 C++ 底层实现和 STL 源码、原理上的认识。
以上书籍同时建议和侯捷老师的视频配合服用,效果更佳。
直接在 B 站搜索「候捷 C++」即可,主要有以下几个系列:
我基本都看了,收获挺大的,建议看下,可以开倍速。
最近发现 B 站关于侯捷老师的 C++ 视频课程几乎全部被下架了,于是自己搜集了一套非常全的视频,大家赶紧去下载保存备用:
看完以上资料,算是 C++ 入门了,应付面试也是足够的,基本到达了正确高效地使用 C++ 这一层面。
是不是听到这有点崩溃,特么的看了这么多,才入门???
如果你想在 C++ 语言上更进一步,那么有以下的书籍推荐:
这本书是 C++ 之父 Bjarne Stroustrup 写的,关于 C++ 的前世今生,以及未来的演进方向,可以了解 C++ 的设计哲学。C++ 复杂的语言特性一直让人诟病,通过这本书,可以看到各种特性引入的目的,也更深入了解到了 C 和 C++ 之间关系。比如 C++ 里有个原则就是所有的实现机制都不能带来额外的运行时开销。
我也正在看这本书。
C++模板元编程属于另外一个世界了,一般公司里开发用得比较少,这个也是一个大坑,如果实在感兴趣可以去看看,感受下 C++ 的博大精深,不过这玩意我也不太会,也不推荐你去花时间在上面。
这是 C++ 社区组织的类似开源峰会那种,每次都会讨论一些关于 C++ 的话题,没事去刷一个,还是挺有意思的。 Youtube 直接搜 CppCon 即可找到。
操作系统这门课,我的感觉是易学难精,但是掌握到日常编程和面试够用还是比较容易的。
那么毕业生或者说你去准备校招面试应该达到怎样的水平:
其中内存、进程、IO 是重点,这几块也是和编程关系最密切的,这里推荐先挑本偏理论的书看看,了解操作系统的全貌:
不必全看,两者任选一本都不错,我自己是仔细看了第二本,因为是我们教材,同时挑着看了现代操作系统部分章节。
这部分看完你应该对下面这些话题有一个清晰认知了:
但是这还不够,看完偏理论的书,当面试官问「进程和线程的区别」时。
大概只能回答出「进程是资源分配的最小单位,线程是CPU调度的最小单位,balabala...」这样正确却普通的答案。
但是如果你了解 Linux 内核的实现,就可以实际出发,讲讲 Linux 中进程和线程是如何创建的,区别在哪里。
比如在 Linux 中进程和线程实际上都是用一个结构体 task_struct来表示一个执行任务的实体。进程创建调用fork 系统调用,而线程创建则是 pthread_create 方法,但是这两个方法最终都会调用到 do_fork 来做具体的创建操作 ,区别就在于传入的参数不同。
深究下去,你会发现 Linux 实现线程的方式简直太巧妙了,实际上根本没有线程,它创建的就是进程,只不过通过参数指定多个进程之间共享某些资源(如虚拟内存、页表、文件描述符等),函数调用栈、寄存器等线程私有数据则独立。
这样是不是非常符合理论书上的定义:同一进程内的多个线程共享该进程的资源,但线程并不拥有资源,只是使用他们。
这也算符合 Unix 的哲学了— KISS(Keep It Simple, Stupid)。
但是在其它提供了专门线程支持的系统中,则会在进程控制块(PCB)中增加一个包含指向该进程所有线程的指针,然后再每个线程中再去包含自己独占的资源。
这算是非常正统的实现方式了,比如 Windows 就是这样干的。
但是相比之下 Linux 就显得取巧很多,也很简洁。
对于进程、线程这块你还可以把 fork、vfork、clone 、pthread_create 这些模块关系彻底搞清楚,对你理解 Linux 下的进程实现有非常大的帮助。
说了这么多,就是想强调一下理论联系实际的重要性。
特别是操作系统,最好的实践就是看下 Linux 内核是怎么实现的,当然不是叫你直接去啃 Linux 源码,那不是一般人能掌握的。
最好的方式是看书,书的脉络给你理得很清晰。
书籍推荐:
这本书恰到好处,即讲清楚了内核实现的要点,又不会通篇源码。
这本书重点关注「第 3 章进程管理」、「第 5 章系统调用」、「第12章内存管理」、「第13章虚拟文件系统」、「第 15 章进程地址空间」
这些章节属于操作系统核心部分,其它如中断处理、块 IO、设备管理根据你自己兴趣选择看下就可以了。
基本上做到这里,操作系统就没什么大问题了。
需要掌握的网络协议和知识:
计网知识比较繁杂,很多同学都反映网络很难学,一大堆的网络协议,依次学完后,还是不知道网络是怎么构成的。
这就是没有用对学习方法,导致只见树木,不见森林。
学习时,推荐你抓住一条主线 「一个数据包是如何发送出去的?」
带着这个问题依次去学应用层、传输层、网络层、链路层,思考这些层之间是如何串联起来的。
这就是自顶向下的思路,那自然要推荐:
这本书从我们最常接触的 HTTP、FTP、SMTP 等应用层协议讲起,可以清晰看到引入各个层的作用。
比如为了区分同一个主机的不用应用,引入了传输层,并使用不用的端口号作为区别;
为了在不同子网间传输数据引入了网络层,并使用 IP 地址寻址路由;
网络层解决了不同子网间路由的问题,但是同一个局域网内确定主机却是通过 MAC 地址,所以引入了链路层来承载 IP 数据包;
同时为了将 IP 地址和 MAC 地址做转换映射又产生了 ARP 协议。
层层递进,逐层揭开网络,非常推荐!
还有一本书:
非常浅显易懂的描述了「一个数据包是如何发送出去的」,也不费时间,看惯了机工社的大黑书,看这种反而有种看小人书的感觉,有基础的话,一天左右就过完了。
只有把握住了整个网络脉络主线才不至于被纷繁复杂的网络协议所搞晕,剩下的就是不断的细化,填充这些主干上的细枝末节。
那么有哪些细节可以去填充呢?
比如 ARP 工作过程、IP 地址、IP 分片、NAT(UDP 打洞)、链路层访问控制协议等等。
还有最重要的 TCP 协议,TCP 也是面试和计网中最重要的概念:
这么多东西肯定需要背,但不要死记,最好带着问题去思考为什么要这样做。
这里列几个问题:
整个 TCP 的核心就是围绕着 可靠传输 + 高效传输(流量控制和窗口管理)
由于 TCP 的细节实在太多,自顶向下那本书有点不太够,所以你需要去看看:
这本书不要从头看,而是挑出其中涉及到 TCP 的章节
到这里,对于整个网络以及 TCP 都应该有了一个全面而细致的认识。
但是计网中还是有一些有意思的问题,如果你没思考过,也许回答不出来。
比如:
这些问题只有当你真正理解了才能回答出,仅仅记住协议的话,估计很难应对灵活的面试题。
此外,网络部分还需要准备 HTTP、HTTPS,推荐:
最后别忘了自己回答一遍那被问烂了、写烂了的问题:
越细越好,五百字以上吧,哈哈哈
C++ 后台开发基本是离不开网络编程的,其实甚至整个后台开发也可以看做是在做网络编程。
只不过别人的框架帮我们做了协议解析、网络数据传输、解封包这些底层操作。
比如 SpringBoot 这种保姆级框架,基本上属于将一个框架能干的事都干完了,以至于我们开发业务只需要定义接收和返回包的数据格式,然后做逻辑处理就完了。
像序列化、解封包、IO 处理这种网络编程必备的脏活业务开发根本不会接触到。
但是网络编程技能还是很重要的,特别是对于 Linux C++ 开发来说。
Linux 下网络编程核心的包括系统编程和网络 IO 两个部分:
推荐的书:
这两本是砖头书,虽然是网络编程和 Unix 系统编程方面的无出其右的圣经,但主要用途还是垫显示器(逃, 个人觉得这种书不是面向读者的,具体原因和如何阅读这种书在后文介绍。
我强烈推荐,这本书前半部分基本是在重复计网基础知识,但是后面几章关于高性能服务器程序框架、高性能IO、IO复用、定时器、多线程编程、线程池和进程池还是讲得非常全面到位的,值得一看,看完基本上对于整个网络编程就有了框架。
这本书同样强烈推荐,这是陈硕大佬写的书,说实话第一部分:C++ 多线程系统编程都直接把我看蒙了,没有想到 C++ 里要做到线程安全这么难,第一章我看了两三遍才看懂吧。。。 这是难得的讲解 C++ 多线程编程的书。
并且在书中,陈硕大佬用了一章讲解了 Muduo 网络库设计与实现,Muduo 比较适合学完基础的网络编程后继续进阶学习如何设计和写一个网络库,是一个高质量的 Reactor 网络库,采用 one loop per thread + thread pool 实现,代码比较简洁,书和源码搭配着看作为学习网络编程方面来说是非常不错。
学完网络编程就可以写点小项目练手了,这里列举几个项目:
作为 C/C++ 程序员,编写的程序不像 Java、Python 这些是在虚拟机上,直接就是在操作系统上运行,那么就必须了解操作系统底层机制和运行原理。
就和 Java 程序员要求了解 JVM 是一个道理,你得熟悉代码运行的平台,才能在出问题的时候准确定位到。
这个也是在我们学校在大三开设的一门课程《System Programing》,从 CMU 引进的,教材也是沿用 CSAPP,这也是我觉得大学上过最值的课了。
我重新认真读 CSAPP 就是在大三上这个课期间,包括做了每个章节附带的 lab, 这是我当时做 Bomblab 的题解:
https://www.jianshu.com/p/479333cbccc4
这里推荐两本书:
不需要我多介绍了
别被名字欺骗了,这不是教你养生的,而是学了会掉头发的硬核知识
两本书侧重点各不相同,CSAPP 非常巧妙的把数字电路基础、二进制与指令集体系、汇编语言、程序设计及优化、存储器体系结构、链接与装载、进程、虚拟内存这一堆来自各不同的计算机学科的核心知识点串在一起,并以程序员的视角呈现,所以这本书的英文名字叫《Computer Systems A Programmer's perspective》。
而程序员自我修养则重在链接、目标文件、装载、库与运行时,看完这本书你会了解到一个 C/C++ 程序是如何被编译成目标文件的,以及 Linux 下目标文件的格式,不同目标文件又是如何被链接成一个可执行程序,在链接时如何处理符号、重定位、地址解析等,以及静态链接、动态链接区别等等,最后可执行文件又是如何被加载进内存,如何和虚拟内存空间映射的。
你可能会觉得这个又是只能用于面试,实际派不上用场的知识?
那简直大错特错,说真的,这两本书,我是反复看了三遍以上,当然后续看都是挑着重点看的。
举个例子吧,写 C/C++ 的同学没少遇到这些编译错误吧:
undefined reference to xxx
Symbol key multiply defined (by xxx.o and yyy.o)
在我大一的时候遇到这些问题简直一脸懵逼,根本连报错都看不懂。
特别是涉及到多文件编程的时候,经常傻乎乎的在头文件中定义变量,导致变量多重定义,这些问题没有学过链接知识的其实很难理解。
在实际编程也是经常会遇到的。
又比如extern、static 这些关键字是如何在编译链接时起作用,变量的申明与定义又有什么区别?
这部分可以算是真正的内功了,提升你对计算机系统的理解,也有助于解决实际编程过程中会出现的问题,当然也会在面试中出现。
数据库首先要学会 SQL 的使用,这里推荐《MySQL必知必会》。
数据库原理方面可以看看《数据库系统概念》,这本书挺厚的,包含了从 SQL 到数据库设计再到数据库原理、分布式数据库都有,可以挑着看,比如关系模型、数据库设计(三大范式)、数据磁盘存储和组织方式、索引、并发控制等。
当然了整个数据库最重要的还是索引和并发控制(锁、MVCC等),这部分也是面试常考的:
这部分推荐两本书:
这两本主要对索引、innodb存储引擎、锁、并发控制讲得比较清楚,建议挑对应章节看。
首先需要掌握常见的数据结构:
常见的算法:
视频可以看看 :
这两个是我看过觉得不错的才在这推荐,第一个是初学数据结构时跟着看,第二个是大三复习时刷的。
入门版书籍可以看看:
稍微进阶点的:
这本书强烈推荐,难度适中,但是全面。
终极版:
这个量力而行就好了。。。 推荐理由是:我不推荐显得没有逼格(:
有了基础的算法思想和数据结构储备,剩下的就是刷题了:
建议必刷
建议分类刷,先易后难,比如数组、二分、二叉树、动态规划,一个一个系列搞定,总结经验,保证 150 道简单和中等以上吧
最重要的是,保持手感,有空就刷一道。
有些同学喜欢看视频,那我也在这里统一推荐一下吧
你的一站式学习网站,用你想学的关键字在这搜就完了
基础课程学习
一些技术课程、公开课学习
Linux C/C++ 可以去看看黑马的,我试看过几集 IO,讲得还是不错的,就是有点慢,个人觉得不如看书。
刷题可以看看牛客左神的视频
计算机网络可以看看 B 站韩立刚或者 mooc 哈工大的
操作系统可以看看学堂在线上清华的《操作系统》
如果你认真看过我前面介绍每一部分的学习路线时,可以发现我特别强调学习抓主线,并且将每一个基础知识的主线给大家列出来了。
这里再次强推,学习新东西的时候,重点是先对整体脉络、知识结构有一个大概的映像和了解,然后抓住这个领域的主线,顺着主干,突出重点去学习。
集中时间,速战速决,不要将时间线拉得太长,越长可能越坚持不下去,效果越差。
对于细枝末节的内容,可以留到实践的时候,用到了再去查!
如果一头扎进零碎的知识,去看手册、字典型的书,那必然是事倍功半的。
细节留给实践去补充,我们的时间要花在刀刃上,注重知识的体系性和框架的建立。
说实话,其实这些书籍或多或少都被各路大神推荐过,确实经典。但是大神们却很少告诉你他们是如何去看的,该怎么去看这些书,难道一本本一页页的挨着啃吗?
这部分才是我今天最想说的部分,「该如何去看大厚书」。
比如我后台就经常有同学问:
这些书该怎么看,可能过来人,准备过秋招的都比较清楚,但是作为还在大二、大三的会比较懵逼。
就拿我当时亲身经历来说,在网上搜网络编程如何学习,很多人都推荐 UNP、APUE。
好嘛,买来看,从第一页挨着挨着看,而且书中的示例代码我大部分也照着敲了,最后看了七八章,发现始终是在学一些 socket api 和 系统 api 的用法,没摸到网络编程的框架思维。
后面我又去搜,看到有人推荐《Linux高性能服务器编程》,去豆瓣看了下了目录,似乎正是我想要的东西。
直接找来 PDF 开始看,果然这本书才真正让我理解了网络编程的整个套路和框架,学到了各种事件处理模式、计时器、信号处理、线程池这些网络编程中很重要的东西。
当然 UNP 和 APUE 也是不能丢的,这两本书我当做了字典查询,比如学到了 IO 部分,回去看 UNP 中关于五种 IO 模型的介绍。
用到 connect、listen、bind 这些函数,再回去看 UNP 第四章,不得不说,UNP 关于这些 socket API 的使用和各种异常情况的处理方式都介绍得非常详细和深入,不愧是网络编程领域的圣经。
但是初学者看却容易在细节中迷失,抓不到纲领,这也是这类书的缺点。
类似 UNP、APUE 这种书本身是面向知识体系的,而不是面向读者,它们其实更像字典,把这个领域内的所有知识,非常细致的堆叠在一起,看上去就是平铺直叙,充斥着细节,对读者极其不友好。并且书里内容实在大而全,很多根本不用学。
比如 UNP 讲了 sctp 这种协议用法、多播、unix 域协议这些实际用得很少的东西,挨着看不仅会看不下去,而且比较浪费时间。
但是它们又是经典的,确实是这些领域内在体系性和深入性上都做得非常好的书。
什么书才是面向读者的呢?
那就是抓住该领域的核心主干,提纲挈领,带领读者由浅入深,同时又有一定的细节,看完让人茅塞顿开。
比如《自顶向下》、《Linux高性能服务器编程》、《Linux多线程服务端编程》、《STL源码剖析》、《Effective C++》、《CSAPP》、《程序员自我修养》等都有各自想要论述的主线在里面,看起来也是一环扣一环,非常循序渐进。
我的看书方法就是对于面向知识体系那种堆砌细节的书,我们先浏览目录,做到对整本书有映像,再大致看一些我们关心的部分,比如 UNP 和 APUE 中 IO、文件、进程控制、信号、线程、线程控制、基本套接字编程 这些是比较重要的模块,其它边角知识,可以用到再去查。
还有一点,很多同学反映看不懂类似 CSAPP 这样的书,那我们都知道,任何一本书基本上都是有前置依赖的。
没有掌握要求的背景知识去看肯定很吃力的。
就比如我大一下只有基础的 C 知识和一丁点计算机导论知识,然后屁颠屁颠的跑去看 CSAPP(学长毕业摆地摊卖书我瞎买的),那时候只知道这本书被誉为神书,但是看到前两三章就蒙了,真的有点难,对于当时的我来说太底层了,根本不知道在说啥,看过也只是看过,就像天空飞过鸟儿,但没有痕迹。
直到后来大三再次拿起,我才意识到这本书的伟大之处就在于将计算机不同学科知识有机的串在了一起。那时候看,更多是一种补充、深入学习以及完善了,因为很多知识分别在数字逻辑、汇编语言、操作系统这些课程中学过了。
所以要明白,你看不懂不是因为你笨没天赋,而是你有前置依赖的知识没有完成,还没学会走,就想跑了。
一般来说,每本书的首页会介绍看这本书需要哪些前置知识,可以关注一下。
还有一种看书的方法,我在复习的时候采用过,那就是横向学习。
比如我复习操作系统,在《操作系统:精髓和设计原理》中看到了关于内存、虚拟内存的各种介绍,看完理论再去看《Linux内核设计与实现》12 章「虚拟内存」、15 章『进程地址空间』,最后再去看《CSAPP》第 9 章『虚拟内存』,这样看下来,基本上内存这块理解得比较透了,这些书关于这块的介绍是各有优缺点的,正好互补。
又比如在《精髓与设计原理》中介绍了进程加载和链接,其实讲得比较偏理论,看完还是觉得似懂非懂。
那我又会去《CSAPP》看第 7 章「链接」,这一章基本讲清了静态链接、目标文件、可重定位目标文件、引用解析、加载这些关于链接的核心概念,但是一个章节讲这么多,难免不够深入。
我又会去看《程序员自我修养》这本书第 4 章「静态链接」、第 6 章 「可执行文件的装载与进程」、第 7 章 「动态链接」,这本书核心主题就是链接、加载,所以这一路看下来,对于链接、加载这块基本上搞得比较透彻了,也许没几个面试官有你清楚。
同样索引你也能从《数据库系统概念》、《高性能MySQL》、《MySQL技术内幕》中挑选对应的章节,串起来看,取每本书优点,这样学习真的很高效也很深入。
这就是我在复习的时候采用的用知识点串联,跨多本书高效精准的复习方式,效果也很不错,春招十几次面试没有一次因为这些基础知识挂过。
啰嗦了一大堆,就是回答这些问题的:
“有些书看的找不到重点,看不下去了,怎么办,比如深入理解计算机系统,UNIX 网络编程,APUE,求指教”、“我不是科班 CSAPP 可能不是全部看得懂,该怎么办?”、“大佬,这么多书看得完吗”、“刚开始看这些书很痛苦怎么办”
这个不好说,根据你的基础和学习效率不同,比如我大一、大二对于一些基础的知识学得比较认真,基础还算可以,按照这样一套走下来也就大半年。大概每天花四五个小时以上吧。
如果真的是连计网、操作系统理论这样的东西一点基础都没的话,那估计得一年以上,毕竟这些内容基本覆盖了科班的核心课程,人家上三年课,你一年解决,已经算很快了好吧。
一年真的足够从小白学起吗?
感觉是差不太多的,但是估计得每天付出五六小时以上了,并且学习方法得当。
你去牛客就会发现,存在各路大三、研一自学转码的同学,最后还能成为 offer 收割机,所以,不要怀疑一年不够,最关键的是你要找到正确的路线,然后执行下去。
文中推荐的书真的全部要看吗?
当然不是,我自己都没看完,但是我的策略已经说过了,基本上大部分书都看了重要的章节,这样看起来是很快的。
并且随着你看书越来越多,基础越来越好,你会发现每本书前面几章都是铺垫基础知识,大部分可以直接跳过,举个例子
《Linux高性能服务器编程》这本书前几章是这样的:
你觉得这些章节在看过《自顶向下》、《TCP/IP详解》之后还有必要看吗?我反正是半天扫过去就完了。
最后,不管说再多方法,再多的路线,最终都需要自己花时间去啃、去执行。
还有一个很多选择 C++ 方向同学都存在的疑惑,在这里我也想解释一下:
C++ 语言特性多,又难学,很多都是底层开发才会用到,C++ 就是个坑,是否应该转 Java、Go 呢?
当然不是的,的确在头条、美团、阿里这种业务部门使用 Go、Java 系更多,首先还是那个观点,校招生对于企业来说都是一张白纸,面试官考察的是你的基础知识和聪明度,来决定是否有培养潜力,语言确实不重要。
那你可能会说,明明各种面经上常常出现 ConcurrentHashMap、虚表、虚函数实现机制这样和语言强相关的问题。
在我看来啊,面试深入问一些语言实现细节,其实不是在考你语言,而是看你是否有主动钻研的意识,是不是只停留在应用的层面,同时也借语言考察一些数据结构、操作系统方面的基础知识。
所以呢,我觉得 C/C++、Java、Go 你深入学习哪一个都可以,关键还是找对相应的学习路线,一直坚持学下去,不要每天都停留在我到底是学 Java 好还是 C++ 好这样无解的问题。
另外,想对学 C++ 的同学说,可能你会发现身边同学都在搞 Java、Go之类的,找工作缺少一些一起复习准备的朋友,有些甚至劝你别学 C++。那这个时候你一定要坚定自己的选择,多在牛客或者网上找找同方向的朋友一起交流、学习。
说实话,就找工作这块来说,个人觉得区别真的是不大的,不管从薪资、面试难度来说都是差不太多,更多的还是算法和基础知识。
而且也有不少同学 Java 进腾讯需要转 C++,C++ 进阿里、美团需要转 Java 的,这都不是事儿。
那 C++ 目前应用场景有哪些呢?
一句话,对性能或者执行效率要求比较高的应用,比如游戏引擎、infra、推荐引擎、存储等,当然也能拿来写业务(没错说的就是鹅厂),也有做 C++ 客户端开发的,主要是 MFC、QT 等。
说实话,像游戏引擎、infra这类都是门槛比较高的,并且招聘的数量也有限,一般人很难进,而且目前互联网公司的业务部门大多使用的是 Java、Go这类语言。
所以 C++ 的需求量是相比 Java、Go这类少很多的,但是同时学习 C++ 也没 Java 那么多,所以相对来说竞争还没那么大,并且 C++ 学的不错,你同样可以去面阿里、美团这种 Java 技术栈的公司,大厂基本不会限制语言的。
这里给一份我的面经和刷题笔记, 包含各大厂Java、C++ 等面经, 看完一定有帮助:
pdf都可以在这个开源仓库进行下载:
https://github.com/imarvinle/awesome-cs-books------update-----
这里有一份现代C++必学书单推荐:
编程指北:想学好 C++,这些书你必须知道 | C++学习路线还有另外一个谷歌大佬也出了一本,很棒:
编程指北:看完这本谷歌师兄的刷题笔记,直接秒杀了 200 道 LeetCode 算法题上面文章有所删减,全文可以看看这里:
万字长文 | 这可能是东半球最保姆级的后台服务器开发学习路线
最后再给大家分享下我整理的这些书,可以在这里获取,对于学习计算机的同学帮助非常大,且十分系统:
这篇文章有点长,一下子可能一下子看不完,大家可以先收藏着,码字太累了,收藏的时候也请来一个素质三连哦~
在服务端接收完数据之后返回一个接收完毕的通知给客户端,告诉客户端我已经把数据接收完了。
技术栈
Spring boot
java
XML (微信在http协议中数据传输方案)
MD5 签名
微信支付术语openid (OpenID是公众号一对一对应用户身份的标识)
app_id (公众号id,登录微信公众号–开发–基本配置中获得;)
key (收款商户后台进行配置,登录微信商户平台–账户中心–API安全-设置秘钥,设置32位key值;)
mch_id (收款商家商户号;)
certPath (API证书, 登录微信商户平台–账户中心-API安全-下载证书)
后端流程服务端需要的核心操作, 总共分为以下几步:
统一下单
前端调起微信支付必要参数 (需加密)
订单结果主动通知 (回调接口)
查询订单结果
结束订单支付接口(关闭订单,支付订单关闭)
代码微信总共支持多种语言的sdk, 在官网可以下载例子, java程序也可以引入微信支付的sdk包, 但是github上的sdk已经很久没有更新了, 最好的选择, 也是我的选择, 在官网上下载sdk项目, 将其中所有java类copy到自己的项目中.
官网sdk下载目录链接: 商户平台首页
微信sdk下载
根据微信sdk生成配置类 WXPayConfig创建IWxPayConfig.class, 继承sdk WXPayConfig.class, 实现sdk中部分抽象方法, 读取本地证书, 加载到配置类中.package core.com.chidori.wxpay;
发起统一下单 AND 前端调起微信支付必要参数回调结果处理核心是支付订单回调时, 需校验加密签名是否匹配, 防止出现模拟成功通知
注意点统一下单的签名和后续前端拉取微信支付的签名需要统一, 也就是都采用MD5加密, 如果2者不同, 会导致前端拉取微信支付fail, 这是一个巨大的坑, 因为这个原因调试了好久, 微信在文档里没有明确标出统一下单的签名校验方式 需要和前端拉取微信支付的签名校验保持一致.微信sdk里的源码需要针对这个问题调整一下, 调整如下:WXPay类需要修改下加密判断,在WXPay构造方法中,调整如下
结束语做完以后, 微信支付的后端逻辑还是很清晰的, 但是在开发过程中很煎熬, 不清楚每个专业术语在微信哪里配置, 加密方式乱的很