- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C++程序设计教程6 第六章 节 性能.ppt
C++程序设计教程(第二版);提高性能的意义:
性能对提高编程能力举足轻重
如何提高性能?
以合理使用资源为前提,尽快完成任务的能力称为效率.效率影响性能,提高效率就能提高性能
学习目标:
1. 扩展视野,对同一问题的不同要求,模仿各种编程技巧与空间布局策略,予以应对.从而对各种不同的问题,亦能应变自如
2. 掌握测试性能的方法,学会测算时/空交换的代价,客观评估自身的编程能力;第六章内容;1. 内联函数 ( Inline Functions );//==================================
#includeiostream
bool isDigit(char); // 小函数
int main( ){
for(char c; cinc c!=\n; )
if(isDigit(c))
std::cout“Digit.\n;
else std::cout“NonDigit.\n;
}//---------------------------------
bool isDigit(char ch){
return ch=0 ch=9 ? 1 : 0;
}//=================================;内联函数的使用经验:;//======================================
#includeiostream
#includetime
using namespace std;
//--------------------------------------
int calc1(int a, int b){ return a+b; }
inline int calc2(int a, int b){ return a+b; }
//--------------------------------------
int main(){
int x[1000], y[1000], z[1000];
clock_t t = clock();
for(int i=0; i1000*1000*1000; ++i)
z[i] = calc1(x[i%1000], y[i%1000]);
cout(clock()-t)/CLK_TCK“without inline\n;
t = clock();
for(int i=0; i1000*1000*1000; ++i)
z[i] = calc2(x[i%1000], y[i%1000]);
cout(clock()-t)/CLK_TCK“with inline\n;
}//=====================================;结果分析:
内联用与不用差很多
结论:
应尽量将函数改造成可内联性质,提高性能;2. 数据结构 ( Data Structures );问题:;采用不同的数据结构;栈方式;向量方式;结论;3. 算法 ( Algorithms );问题:;算法1:递归法 优点:算法简单,容易编程 缺点:栈空间负担过重,调用开销过大;算法2:迭代法 优点:节省空间,节省时间 缺点:编程相对复杂;算法3:向量迭代法 优点:节省时间 缺点:n越大,占用堆空间越多;算法4:直接计算法 优点:节省时间 缺点:引入了浮点计算;fibo1:只在示意性编程中使用,但并不是否定一切递归法
fibo2:在讲究性能的场合中使用,它省空间省时间,但在n很大的场合中,性能比不上fibo4
fibo3:可以数组代替向量,提高低级编程的性能,它易编易用,还可以读取中间项的值,但在一味追求性能的场合中,比不上fibo2
fibo4:在n不太大时,与fibo2相当,在n趋向很大时,其性能优势便充分体现;4. 数值计算 ( Numerical Computation );数值计算的参数描述;矩形法;辛普生法 ;性能比较;5. 标准C++ 算法 ( Standard C++ Algorithms );容器的区间表示;逐一读入两个01字串,比较是否含有相同元素;分别排序,直接加以字串比较是直截了当的思路:;避免排序,分别统计两个字串中01的个数则性能更优:( 排序至少做O(nlogn)数量级运算,统计只做O(n)数量级运算 );字串中非0即1的特征,可以避免多余的统计,进一步提高性能:;6. 动态内存 ( Dynamic Memory );使用容器,便是自动使用堆内存;若每个数据的处理,都要用到已经处理的数据时,保存历史数据,则可以改善时间性能;空间换时间版;7. 低级编程
您可能关注的文档
- Bodie2e_Chapter06 The Analysis of Investment Projects 英文版PPT金融学(第二版) 教学文稿.ppt
- Bodie2e_Chapter06 The Analysis of Investment Projects 英文版PPT 金融学(第二版)教学文稿.ppt
- Bodie2e_Chapter07 Principles of Market Valuation 英文版PPT 金融学(第二版)教学文稿.ppt
- Bodie2e_Chapter07 Principles of Market Valuation 英文版PPT金融学(第二版) 教学文稿.ppt
- Bodie2e_Chapter08 Valuation of Known Cash Flows Bonds 英文版PPT 金融学(第二版)幻灯片课件.ppt
- Bodie2e_Chapter08 Valuation of Known Cash Flows Bonds 英文版PPT金融学(第二版) 幻灯片课件.ppt
- Bodie2e_Chapter09 Valuation Common Stocks 英文版PPT 金融学(第二版)教学文稿.ppt
- Bodie2e_Chapter09 Valuation of Common Stocks 英文版PPT金融学(第二版) 教学文稿.ppt
- Bodie2e_Chapter10 Principles of Risk Management 英文版PPT金融学(第二版) 幻灯片课件.ppt
- Bodie2e_Chapter11 Hedging, Insuring, and Diversifying 英文版PPT 金融学(第二版)幻灯片课件.ppt
文档评论(0)