C&C++   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了左侧后增量大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我的印象是,后增量(OR preincrement)只能在相等(=)的右侧进行.但我能够编译下面的代码.
你能帮助我理解这个特定的代码,特别是在线下.
来源: http://www.ibm.com/developerworks/library/pa-dalign/
*data8++ = -*data8;


void Munge8( void *data,uint32_t size ) {
    uint8_t *data8 = (uint8_t*) data;
    uint8_t *data8End = data8 + size;

    while( data8 != data8End ) {
        *data8++ = -*data8;
    }
}

解决方法

所以,我很确定这是未定义的行为.除最终分号外没有序列点:
*data8++ = -*data8;

如果data8等于0x20,则它等于:

*(0x20) = -*(0x20);

要么

*(0x20) = -*(0x24);

因为没有办法做出这个决定,(因为你在读取变量时编辑了一个变量,没有交错序列点),这是未定义的行为.

我们可以谈谈下面这段代码的作用.这可能是上述代码的意图.

while( data8 != data8End ) {
    *data8 = -*data8;
    data8++;
}

在这里所做的事情希望更加直截了当.您正在使用输入数组,并查看它,因此它是一系列8位数字.然后,就地,你否定每一个.

大佬总结

以上是大佬教程为你收集整理的左侧后增量全部内容,希望文章能够帮你解决左侧后增量所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:增量左侧