当前位置: 首页 > news >正文

汕头网站开发找哪里wordpress apply_filters

汕头网站开发找哪里,wordpress apply_filters,如何建设网站的外链,网站建设为大学生服务点击蓝字关注我们相信很多人遇到过这样的问题#xff1a;printf(%d,%d,i,i);也纠结过这个问题#xff0c;到底答案是什么。确没有一个参考的资料。唯一知道的是#xff0c;几乎所有C语言教材都这么讲#xff1a;i就是先使用i的值再使i自身加一#xff0c;而i则… 点击蓝字关注我们相信很多人遇到过这样的问题printf(%d,%d,i,i);也纠结过这个问题到底答案是什么。确没有一个参考的资料。唯一知道的是几乎所有C语言教材都这么讲i就是先使用i的值再使i自身加一而i则是先使i自身加一然后在使用i的值。出于对真理的追求。今天我们彻底弄明白此问题譬如这样的话int a,b; int i10j10; ai; bj;我们可以很清楚的知道a和b的值分别将是10和11。这点毫无疑问因为无论在任何平台任何编译器上运行都是这个结果然而对于这样的程序int a,b; int i10j10; a(i)(i)(i); b(j)(j)(j);各位试想答案将是多少我们可以放到编译器上运行看一下结果如下先看看windows下常用的VC6结果恩看到了是30和37嗯但..这个结果好像有点怪。那再看看Linux下gcc的结果哦竟然也是30  37 。那我们再看看古老一点的TurboC的结果结果成了30  39  , 喔~还真有点怪。当然就C语言代码来看i 和 i 都只有一行看起来似乎二者的执行效率一样了其实不是的在学习C语言时教材和老师一般都会强调 i 和 i 的区别例如下面这段C语言代码int i , j, k; i  0; j  i; i  0; k  i;这段C语言代码执行后j 和 k 的值并不相等j 等于 0k 等于 1。既然执行结果有差异那么执行效率很有可能也是有差异的事实的确如此。查看上述C语言代码对应的汇编代码如下编译器版本为gcc 4.8.4可见ji; 计算机需要 4 条指令来解释比执行 ki; 多出了一条指令。多出的一条指令为在对 i 执行自加操作之前先保存 i 的当前值留作稍后使用赋值为j。这是怎么回事呢不同的编译器结果还不一样呢而且这样看来似乎 i 的执行效率比 i 高一些为何不同的编译器结果不一样要说起这其中的原因我们要先明白两个知识点。即“副作用”与“顺序点”。这里我们引用《C Primer Plus》的说法“现在我们再讨论一些C的术语。副作用(side effect)是对数据对象或文件的修改。例如语句states 50的副作用是将变量states的值设置为50。这是副作用这看起来更像是主要目的然而从C的角度来看主要目的是对表达式求值。给C一个表达式46C将计算它的值为10。给C一个表达式states50C将计算它的值为50。计算这个表达式的副作用就是把变量states的值改变为50。跟赋值运算符一样增量运算符和减量运算符也有副作用它们主要由于副作用而被使用。一个顺序点(sequence point)是程序执行中的一点在该点处所有的副作用都在进入下一步之前被计算。在C中语句里的分号标志了一个顺序点。它意味着在一个语句中赋值运算符、增量预算符及减量运算符所做的全部改变必须在程序进入下一个语句前发生。任何一个完整的表达式的结束也是一个顺序点。什么是完整的表达式呢一个完整的表达式(full expression)是这样一个表达式—-它不是一个更大的表达式的子表达式。完整的表达式的例子包括一个表达式语句里的表达式和在一个while循环里作为判断条件的表达式。顺序点帮助阐明后缀增量动动作何时发生。例如考虑下面的代码while(guests10) printf(“%d\n”guests);本程序然而因为guests10是while循环的判断条件所以它是一个完整的表达式这个表达式的结束就是一个顺序点。因此C保证副作用(增加guests的值)在程序进入printf()前发生。同时使用后缀形式保证了guests在于10比较后才增加。现在考虑这个语句Y(4 x)(6 x);表达式4x不是一个完整的表达式所以C不能保证在计算子表达式4x后立即增加x。这里完整表达式是整个赋值语句并且分号标记了顺序点所以C能保证的是在程序进入后续语句前x将增加两次。C 没有指明x是在每个子表达式被计算后增加还是在整个表达式被计算后增加这就是我们要避免使用这类语句的原因。 这是《C Primer Plus》的说法相信您应该有一定答案了。没错那就是对于i10;(i)(i)(i)这样的语句。C语言标准并没有作规定。有的编译器计算出来是39因为会使i的值自增三次变为13然后使用增加三次之后也就是13的3个值相加为39。而有的编译器计算结果则为37如VisaulC6.0则会先计算前两个i的值为12第三个i的值变成了加三次以后的值为13因此结果是12121337。如果有心的话您可以分别在VC6和TC上本别测试;(i)(i)(i) (i)的值来洞悉不同编译器的处理规则。那么回到最初的printf的问题明白求值的顺序之后再来看printf的求值问题printf的参数都是从左到右依次压入栈内所以计算起来求值运算的时候则是由右至左(栈的特点即先进后出)那么至此想必您已经完全想明白了这类问题的全部了所以讲到这里想必大家就清楚缘由了不同编译器的处理过程是不同的。所以并没有唯一的标准答案现在大家明白了吗为何i比i执行效率高一些呢那为了写出效率更高的C语言程序以后是不是应该尽量使用 i而不是 i 了呢例如下面这样的C语言代码for(i0; i10; i); for(i0; i10; i);是不是上面那行C语言代码的执行效率低于下面的呢只能说理论如此实际上现代C语言编译器已经足够聪明它会根据上下文编译C语言代码。应该明白i 和 i 的效率差异主要来自于处理 i 时需要先保存 i 的当前值留作稍后使用。如果之后没有人使用 i 的当前值也就是说没有C语言代码读取 i 的值编译器实在没有必要保存 i 的当前值了因此就会将这一步优化掉。为了便于分析我们编写下面这样的C语言代码int i  0; i; i;与上面的例子相比区别在于在执行 i 时没有人关心 i 的当前值了。查看这段C语言代码对应的汇编代码显然i 和 i 对应的指令是一模一样的不再有执行效率上的差异。C语言中的 i 和 i 是有区别的这就有可能带来效率上的差异。如果有代码关心 i 执行时的 i 当前值程序在对 i 进行自加操作时将不得不先保存 i 的当前值。而 i 就无需保存当前值这就会带来效率上的差异。如果没人关心 i 的当前值那么现代大多数C语言编译器将会将这一差异优化掉此时 i 和 i 不再有效率上的差异。*声明本文于网络整理版权归原作者所有如来源信息有误或侵犯权益请联系我们删除或授权事宜。戳“阅读原文”我们一起进步
http://www.sadfv.cn/news/75665/

相关文章:

  • 网站备案需要哪些东西wordpress图片粘贴插件
  • 自己做的旅游网站 介绍钢结构平台
  • 自助建站软件自动建站系统苏州网站开发公司兴田德润优惠吗
  • 学做宝宝衣服网站好电子商务网站建设与管理期末考试题
  • 网站建设流程周期公司入口网站app
  • 代理上海建站公司注册出口网站制作
  • 永川网站建设熊掌号做网站开专票税钱是多少个点
  • 邯郸网站设计制作wordpress伪静态规则
  • 中国开发网站的公司北京网站建设 公司
  • 用excel做网站展厅设计搭建
  • 餐饮公司网站模板开发公司运营部职责
  • 泰州网站建设专业团队目前最好的引流方法
  • 逻辑图在线制作网站深圳对留学生创业政策
  • 建网站和开发网站网站建设方案书模板 备案
  • wap网站微信分享代码多店铺开源商城系统
  • zhi做网站做前端常用的网站及软件下载
  • 青岛开发区网站建设公司crm客户管理系统免费软件
  • 内设网站个人网站备注
  • 如何使用网站模板建设网站珠海企业网站建设
  • 建立个人视频播放网站微信h5制作平台
  • 网站会员权限佛山做优化的公司
  • 负责网站的建设规划微信公众平台网页开发
  • 免费发布推广信息的网站网站建设方案和报价表
  • 做国外网站推广17一起做网站广州
  • 网站不备案能用吗生成html网站地图
  • 网站备案类型网站互联
  • 网站制作 建站汽车网站开发思路
  • 上海网站建设在哪免费的网站建设
  • 多模块内容网页布局设计曲靖seo
  • 做网站 需求网页制作软件app免费