C语言深度剖析读书笔记.docxVIP

  1. 1、本文档共17页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C语言深度剖析读书笔记

C语言深度剖析读书笔记第1章关键字1.1、定义与声明的区别:定义创建了对象并为对象分配了内存,声明没有分配内存1.2、register请求编译器尽可能将变量存在CPU寄存器中以提高访问速度,register变量必须为CPU寄存器所能接受的类型,它须是一个单一的值,并且长度=整型的长度,由于register变量可能不放在内存中,故不可以用””来获取它的地址1.3、函数前面加static使得函数成为静态函数,它的作用域仅限于本文件中,故又称内部函数1.4、case关键字后面只能是整数或字符型的常量或常量表达式。?? ??????const int a = 5;??? case a:?? //const只读变量,编译出错,case label does not reduce to an integer constant??? case 1.1: //小数,编译出错,case label does not reduce to an integer constant??? case 3/2:? //没有问题,分数会被转换成整数1.5、“跨循环层”的概念本身是说,由外层循环进入内层循环是要重新初始化循环计数器的,包括保存外层循环的计数器和加载内层循环计数器,退出内层的时候再恢复外层循环计数器。把长循环放在里面可以显著减小这些操作的数量,还可以增加cache的命中率。在多重循环中,如果有可能,应当将最长的循环放在最内层,最短的循环放在最外层,以减少CPU跨切循环层的次数。for(i = 0; i 50; i++){????for(j = 0; j 10000; j++){????}}效率比下面这个高for(i = 0; i 10000; i++){????for(j = 0; j 50; j++){????}}1.6、void指针的算术操作????void *pvoid;????pvoid++; //ANSI认为是错误的,因为它认为进行算术操作的指针必须知道它所指向的数据类型大小????pvoid += 1; //ANSI认为是错误的????//但GNU指定void *的算术操作跟char *相同。1.7、const????编译器通常不为普通const?只读变量分配存储空间,而是将它们保存在符号表中,这使得它成为一个编译期间的值,没有了存储与读内存的操作,使得它的效率也很高。例如:#define M 3//宏常量const int N=5; //此时并未将N?放入内存中......int i=N;//此时为N?分配内存,以后不再分配!int I=M;//预编译期间进行宏替换,分配内存int j=N;//没有内存分配int J=M;//再进行宏替换,又一次分配内存!const?定义的只读变量从汇编的角度来看,只是给出了对应的内存地址,在程序运行过程中只有一份拷贝。#define?定义的宏常量在内存中有若干个拷贝。#define?宏是在预编译阶段进行替换,而const?修饰的只读变量是在编译的时候确定其值怎么看const修饰哪个对象先忽略类型名(编译器解析的时候也是忽略类型名)。看const?离哪个近。离谁近就修饰谁。const int *p; //const *p//const?修饰*p,p?是指针,*p?是指针指向的对象,不可变int const *p; //const *p//const?修饰*p,p?是指针,*p?是指针指向的对象,不可变int *const p; //*const p//const?修饰p,p?不可变,p?指向的对象可变const int *const p; //前一个const?修饰*p,后一个const?修饰p,指针p?和p?指向的对象都不可变1.8、volatile????编译器遇到这个关键字声明的变量,编译器对访问该变量的代码就不再进行优化,从而可以提供对特殊地址的稳定访问先看看下面的例子:int i=10;int j = i;//(1)语句int k = i;//(2)语句这时候编译器对代码进行优化,因为在(1)(2)两条语句中,i?没有被用作左值。这时候编译器认为i?的值没有发生改变,所以在(1)语句时从内存中取出i?的值赋给j?之后,这个值并没有被丢掉,而是在(2)语句时继续用这个值给k?赋值。编译器不会生成出汇编代码重新从内存里取i?的值,这样提高了效率。但要注意:(1)(2)语句之间i?没有被用作左值才行。再看另一个例子:volatile int i=10;int j = i;//(3)语句int k = i;//(4)语句volatile?关键字告诉编译器i?是随时可能发生变化的,每次使用它的时候必须从内存中取出i的值,因而编译器生成的汇编代码会重新从i?的地址处读取数据放在k?中。这样看来

文档评论(0)

2017ll + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档