有两个方向
1 算法。
找本算法和数据结构的书
一般有参考代码
不同的算法,在网上也可以找到优秀代码
2 功能
找开源软件 尤其是用的比较广的
里面代码写的都不错
可以看看
1. webbench
webbench是一个在linux下使用的非常简单的网站压测工具。它使用fork()模拟多个客户端同时访问我们设定的url,测试网站在压力下工作的性能,最多可以模拟3万个并发连接去测试网站的负载能力。webbench使用c语言编写, 代码实在太简洁,源码加起来不到600行。参考:八
2. tinyhttpd
tinyhttpd是一个超轻量型http server,使用c语言开发,全部代码只有502行(包括注释),附带一个简单的client,可以通过阅读这段代码理解一个 http server 的本质。参考:六
3. cjson
cjson是c语言中的一个json编解码器,非常轻量级,c文件只有500多行,速度也非常理想。
cjson也存在几个弱点,虽然功能不是非常强大,但cjson的小身板和速度是最值得赞赏的。其代码被非常好地维护着,结构也简单易懂,可以作为一个非常好的c语言项目进行学习。参考:五
4. cmockery
cmockery是google发布的用于c单元测试的一个轻量级的框架。它很小巧,对其他开源包没有依赖,对被测试代码侵入性小。cmockery的源代码行数不到3k,你阅读一下will_return和mock的源代码就一目了然了。
主要特点:
免费且开源,google提供技术支持;
轻量级的框架,使测试更加快速简单;
避免使用复杂的编译器特性,对老版本的编译器来讲,兼容性好;
并不强制要求待测代码必须依赖c99标准,这一特性对许多嵌入式系统的开发很有用参考:六
5. libev
libev是一个开源的事件驱动库,基于epoll,kqueue等os提供的基础设施。其以高效出名,它可以将io事件,定时器,和信号统一起来,统一放在事件处理这一套框架下处理。基于reactor模式,效率较高,并且代码精简(4.15版本8000多行),是学习事件驱动编程的很好的资源。参考:二
6. memcached
memcached 是一个高性能的分布式内存对象缓存系统,用于动态web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态数据库驱动网站的速度。memcached 基于一个存储键/值对的 hashmap。memcached-1.4.7的代码量还是可以接受的,只有10k行左右。参考:八
7. lua
lua很棒,lua是巴西人发明的,这些都令我不爽,但是还不至于脸红,最多眼红。
让我脸红的是lua的源代码,百分之一百的ansi c,一点都不掺杂。在任何支持ansi c编译器的平台上都可以轻松编译通过。我试过,真是一点废话都没有。lua的代码数量足够小,5.1.4仅仅1.5w行,去掉空白行和注释估计能到1w行。参考:二
8. sqlite
sqlite是一个开源的嵌入式关系数据库,实现自包容、零配置、支持事务的sql数据库引擎。 其特点是高度便携、使用方便、结构紧凑、高效、可靠。足够小,大致3万行c代码,250k。
9. unix v6
unix v6 的内核源代码包括设备驱动程序在内 约有1 万行,这个数量的源代码,初学者是能够充分理解的。有一种说法是一个人所能理解的代码量上限为1 万行,unix v6的内核源代码从数量上看正好在这个范围之内。看到这里,大家是不是也有“如果只有1万行的话没准儿我也能学会”的想法呢?
另一方面,最近的操作系统,例如linux 最新版的内核源代码据说超过了1000 万行。就算不是初学者,想完全理解全部代码基本上也是不可能的。
10. netbsd
netbsd是一个免费的,具有高度移植性的 unix-like 操作系统,是现行可移植平台最多的操作系统,可以在许多平台上执行,从 64bit alpha 服务器到手持设备和嵌入式设备。netbsd计划的口号是:”of course it runs netbsd”。它设计简洁,代码规范,拥有众多先进特性,使得它在业界和学术界广受好评。由于简洁的设计和先进的特征,使得它在生产和研究方面,都有卓越的表现,而且它也有受使用者支持的完整的源代码。许多程序都可以很容易地通过netbsd packages collection获得。
11,最值得阅读学习的 10 个 c 语言开源项目代码都有参考下载链接,如果你学习上需要这些,我有答案链接学习 ,把前7题( 参考:数字)组合就找到我了,相信这对于聪明的你不难哦!
用户登录
还没有账号?立即注册
用户注册
投稿取消
文章分类: |
|
还能输入300字
上传中....