程序员如何实现高速成长?

很多读者都问过一个问题:程序员如何实现高速成长?之前也写过相关的文章,强调的主要是夯实计算机体系基础知识 。
 
再说另一个诀窍:多看经典开源项目,这些项目大多是众多顶尖程序员智慧的结晶,通常都有着不错的架构和代码实现 。甚至有可能的话,在深入理解某个开源项目之后,最好能参与开源项目的研发 。
 
拿我自己举例,本来是个C++菜鸡,后来因为在360遭遇领导被调岗,从菜鸡状态就被推到部门技术专家的位置,当时差点就把团队玩废了 。
 
好在无意中发现了可以通过看开源代码快速成长,于是每天半夜疯狂研究,才平稳过关 。
 
经典开源代码无论是架构还是实现,都充满了编程之美,学习优美的代码能最快速度找到前进的方向 。
 
今天也给大家推荐几个很不错的C++开源项目:
 
1.TinyWebServer
 
这是一个帮助初学者快速实现网络编程、搭建属于自己的轻量级Web服务器的小项目 。
 
项目虽小但真的五脏俱全:
 

  • 使用线程池、非阻塞Socket、epoll(ET/LT均实现)、事件处理(Reactor及模拟Proactor)的并发模型 。
  • 使用状态机解析HTTP请求报文,支持解析GET和POST请求
  • 访问服务器数据库实现web端用户注册、登录功能,可以请求服务器图片和视频文件
  • 实现同步/异步日志系统,记录服务器运行状态
  • 经Webbench压力测试可以实现上万的并发连接数据交换
 
代码地址:
 
https://github.com/qinguoyi/TinyWebServer
 
2. OpenSSL
 
一个强大的安全套接字层密码库,加密HTTPS,加密SSH都贼好用,同时它还可以用于跨平台密码工具 。
OpenSSL实现了以下功能:
 
  • 数据保密性:信息加密就是把明码的输入文件用加密算法转换成加密的文件以实现数据的保密 。加密的过程需要用到密钥来加密数据然后再解密 。
  • 数据完整性:加密也能保证数据的一致性 。例如:消息验证码(mac),能够校验用户提供的加密信息,接收者可以用MAC来校验加密数据,保证数据在传输过程中没有被篡改过 。
  • 安全验证:加密的另外一个用途是用来作为个人的标识,用户的密钥可以作为他的安全验证的标识 。SSL是利用公开密钥的加密技术(RSA)来作为用户端与服务器端在传送机密资料时的加密通讯协定 。
 
代码地址:
 
https://www.openssl.org/source
 
3.log4cpp
 
一个支持多线程、重定向的强大日志库,精简的代码实现绝对能让你有所收获 。
Log4cpp有以下优点:
 
  • 提供应用程序运行上下文,方便跟踪调试
  • 可扩展的、多种方式记录日志,包括命令行、文件、回卷文件、内存、syslog服务器、Win事件日志等
  • 可以动态控制日志记录级别,在效率和功能中进行调整
  • 所有配置可以通过配置文件进行动态调整
  • 支持JAVA、C++、C、Python等多种语言
 
代码地址:
 
http://log4cplus.sourceforge.net
 
4.Chromium
 
这个开源代码学习起来难度较大,光是编译通过都要花费不力气,但的确值得好好学习 。
 
还记得我从初中级工程师进化到高级工程师就是在一个个通宵研读Chromium代码中度过的 。
 
Chromium的确够复杂,比如Chromium的多进程架构图:
程序员如何实现高速成长?

文章插图
 
chromium的代码目录包含这些模块:
 
base:通用代码集合基础组件实现库,包含字符串、文件、线程、消息队列等工具类集合 。
cc:负责渲染绘制,chrome为什么高效就是因为有它 。chrome:浏览器界面模块,大量调用了cc提供的接口 。
content:多进程沙盒浏览器莫款,管理多进程和多线程 。
gpu,OpenGL封装实现:CommandBuffer和OpenGL的兼容支持模块 。
net:网络功能实现模块 。
media:多媒体封装代码,实现视频播放等功能 。
mojo:跨语言(C++ / Java / JavaScript)跨平台的进程间对象通信模块,类似AIDL的功能 。
skia:图形库 。
third_party:排版引擎 。


推荐阅读