摘要:两个指针所指向位置相同,实际为同一个指针。四求值顺序总结语言中只有四个运算符,明确规定了求值顺序和先对左边求值,只在需要时对右边求值如此避免除错误。在结果为真是返回,结果为假是返回。原因一只要的值都限制在和的结果始终相同。
目录
结论一:复制指针并不会复制指针所指向的内容。两个指针所指向位置相同,实际为同一个指针。
结论而:开辟两个数组,即使两个数组内容相同,地址也绝不相同。
int main(){ int i = 0; int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 }; for (i = 0; i < 13; i++) { arr[i] = 0; printf("haha"); } return 0;}
计算的结果是程序陷入死循环
分析:1.栈区默认先使用高地址,再使用低地址 2.数组内元素随下标增长,地址由低到高变化
调试后即可发现,i与arr[9]的地址相差3字节,所以i即为实际不存在的arr[12].
[补充知识:ANSI c标准允许这种用法——数组中溢界元素的地址位于数组所占内存之后,这个地址可以进行赋值和比较,但是不能解引用(若是数组之前存在溢界则语法不允许)]
十米长的围栏每一米就需要一根栏杆支撑,则共需要几根栏杆? 11
栏杆问题你若不假思索可能会回答为10。栏杆问题的根源正是加减一带来的困惑
对此我们坚持以下原则
原则一:考虑最简单的特例(如考虑20到10间有几个数,20-10还要+1吗。不妨考虑10到10有几个数)
原则二:仔细计算边界
而在实际编程中,一个编程技巧则可以"一言以蔽之",即不对称边界。
x>=0 && x<16 要优于 x>=0 && x<=15
不对称边界上界-下界就是之间所包含的数。
总结:c语言中只有四个运算符(&& ;|| ;?: ;,)明确规定了求值顺序
&&和||先对左边求值,只在需要时对右边求值:
if(y!=0 && x/y>a)
如此避免除0错误。
特别注意,赋值操作符不保证任何求值顺序,即使考虑了优先级和结合性,也会有意想不到的错误
int i=0;while(i
对于以上的代码,就不能确定y是否在i自增之前求值。
问题代码1:c+--c(我们可以根据"大嘴法"判断为c+(--c)),但c自增的先后不得而知)
问题代码2:int a=(++i)+(++i)+(++i) (同理)
问题代码3:answer=func()-func()*func() (我们不知道哪个func被先调用)
这三种运算符返回值都为0或1。在结果为真是返回1,结果为假是返回0。
考虑一下代码,其功能是查询表中一个特定元素
int i = 0;while (i < tabsize && tab[i] != x){ i++;}
现分析将&&替换成&仍然能"正常工作"的原因。
原因一:只要xy的值都限制在0~1,x&&y和x&y的结果始终相同。
原因二:数组结尾之后的下一个元素,只要不改变他的值而仅仅是读取,没有什么大的危害
原因三:不同与&&的求值顺序,&要求两边都要被求值
如果tabsize大小等于tab中元素的个数,即使i=tabsize后还会继续查找下去,陷入死循环
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/119671.html
摘要:学单片机多去官网上查资料,下载手册,像我入门的单片机经常去官网,还有学的系列板子,公司的官网的官方例程给的很详细,在英文视角阅读对你大有益处。 目录 1.C语言经典 2.单片机系列 3.Python方面 4.嵌入式LWip协议 5.Android 6.C++经典书籍 7.Linux开发 ...
摘要:而对于二维数组,因为内存连续性的原因,内存并不会真真的开辟一个二维空间,而是连续依次存入二维数组的每个数据。之所以有二维数组的说法是为了分析问题方便。二维数组的实质是一维数组,只是其元素类型是一维数组类型。 ...
内容介绍 词法陷阱介绍1 =不同于==2 & 和 | 不同于 && 和 ||3 词法分析中的贪心法4 整形常量问题5 字符与字符串问题 词法陷阱介绍 探讨符号和组成符号的字符间的关系,以及有关符号含义的一些常见误解 1 =不同于== =:赋值操作符,将右操作数的值放到左操作数的空间里面。 ==:关系操作符,用来比较左右两个数,若相等则为1,若不相等则为0。 当 == 写成 = 的后...
摘要:从业务流程上,应得到以下信息主流程是什么条件备选流程是什么数据流向是什么关键的判断条件是什么测试用例设计完成以上两步则可进行测试用例设计,功能测试用例,应尽量考虑边界异常性能的情况,以便发现更多的隐藏问题。 为什么测试人员要参加需求分析?也就是进行测试需求分析的目的是什么? 第一、把用户需求...
摘要:是陷阱函数对应的反射方法,同时也是操作的默认行为。对象外形指的是对象已有的属性与方法的集合,由于该属性验证只须在读取属性时被触发,因此只要使用陷阱函数。无论该属性是对象自身的属性还是其原型的属性。 主要知识点:代理和反射的定义、常用的陷阱函数、可被撤销的代理、将代理对象作为原型使用、将代理作为类的原型showImg(https://segmentfault.com/img/bVbfWr...
阅读 853·2023-04-26 00:11
阅读 2651·2021-11-04 16:13
阅读 2100·2021-09-09 09:33
阅读 1470·2021-08-20 09:35
阅读 3816·2021-08-09 13:42
阅读 3603·2019-08-30 15:55
阅读 1035·2019-08-30 15:55
阅读 2216·2019-08-30 13:55