一次简单C程序的性能优化
浏览:5583次 出处信息
下面这段简单的程序, 如何优化?
以下是代码片段: #include void main () { int i; for (i=0;i<20000000;i++) { printf("%012d\\n",i); } } |
下午居然想到要来优化这段程序, 并且写出了更好的程序, 性能提升了30%, 从18秒提升到了12秒.
以下是代码片段: #include typedef struct _NUMERLIST { int len; char buf[5]; } NUMBERLIST; void printNumber(int num, NUMBERLIST numlist[]) { int v_num,i,j,k,pos=0; char tmpbuf[32]; memset(tmpbuf,0,32); v_num=num; for(i=3;i>=0;i--) { v_num = num; for(k=0;k v_num = v_num % 1000; if (v_num > 999) pos = pos + sprintf(tmpbuf+pos,"%03d", v_num); else { memcpy(tmpbuf+pos, numlist[v_num].buf,3); pos = pos + 3; } } printf("%s\\n", tmpbuf); } void main () { NUMBERLIST numlist[1000]; int i; for (i=0;i<1000;i++) { sprintf(numlist[i].buf, "%03d", i); } for (i=0;i<20000000;i++) { printNumber(i, numlist); } } |
如果优化一下两个程序的IO, 采用缓冲输出, 估计第二段程序更显优势.
建议继续学习:
- WEB系统需要关注的一些点 (阅读:14066)
- 30分钟3300%性能提升――python+memcached网页优化小记 (阅读:12110)
- 基于SSD的数据库性能优化 (阅读:7386)
- jQuery性能优化指南 (阅读:7303)
- mysql sql 百万级数据库优化方案 (阅读:5034)
- 一次神奇的MySQL优化 (阅读:4870)
- PHP最佳实践 (阅读:4921)
- Linux 64位, MySQL, Swap & Memory 优化 (阅读:4460)
- Mysql中的排序优化 (阅读:4340)
- PHP 性能优化技巧-google (阅读:4389)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:关于音乐搜索
后一篇:Paxos在大型系统中常见的应用场景 >>
文章信息
- 作者:anysql 来源: AnySQL.net
- 标签: 优化
- 发布时间:2009-11-06 09:17:49
建议继续学习
近3天十大热文
- [66] Oracle MTS模式下 进程地址与会话信
- [66] Go Reflect 性能
- [65] 如何拿下简短的域名
- [59] android 开发入门
- [59] 图书馆的世界纪录
- [59] IOS安全–浅谈关于IOS加固的几种方法
- [58] 【社会化设计】自我(self)部分――欢迎区
- [53] 视觉调整-设计师 vs. 逻辑
- [47] 界面设计速成
- [46] 读书笔记-壹百度:百度十年千倍的29条法则