共有1.c、2.c、3.c三个文件.定义int i=1;尝试输出++i + ++i1.c当中变量i是main函数的局部变量2.c当中:变量i被volatile修饰3.c当中:变量i是全局变量对于1.c,gcc编译器给出答案6,clang给出5.对于2.c和3.c,gcc编译器给出答案5.也就是说,对gcc编译器,volatile和全局变量某种程度上效果一致。这是为什么呢?
Volatile 的作用是告诉编译器不要使用寄存器优化上下文访问,因为可能会被其它线程改写。如果说这个跟全局变量的结果一致,也只能说碰巧了,不能说这个方法就肯定有效。你的这个例子其实有点过于简单了,只做了两个测试就开始总结,其实是没太多说服力的。只能说第一个可能使用了寄存器优化导致了错误。
Volatile 的作用是告诉编译器不要使用寄存器优化上下文访问,因为可能会被其它线程改写。如果说这个跟全局变量的结果一致,也只能说碰巧了,不能说这个方法就肯定有效。
你的这个例子其实有点过于简单了,只做了两个测试就开始总结,其实是没太多说服力的。
只能说第一个可能使用了寄存器优化导致了错误。