淡笑无痕丶 发表于 2020-2-19 14:27:47

SIE39视频最后一段的代码运行结果不相同

#include <stdio.h>

int main(void)
{
        char a = 0, b = 0;
        int* p = (int*)&b;
        *p = 258;
        printf("%d %d", a, b);
        return 0;
}

照着小甲鱼老师的打出来的,VS2019输出是0和2是怎么回事?

jackz007 发表于 2020-2-19 14:37:47

本帖最后由 jackz007 于 2020-2-19 14:44 编辑

      char 最大只能表达到 127,即便是 unsigned char 最大也只能表达到 255,根本无法表达 258。所以,为了避免溢出,得把 a、b 定义为 int
#include <stdio.h>

int main(void)
{
      int a = 0 , b = 0   ;
      int * p = & b         ;
      * p = 258             ;
      printf("%d %d", a, b) ;
      return 0            ;
}
      这个代码的显示结果是:
a = 0 , b = 258

      如果是专门看溢出后的效果,可以这么改:
#include <stdio.h>

int main(void)
{
      char a = 0 , b = 0   ;
      char * p = & b         ;
      * p = (char )258       ;
      printf("%d %d", a , b) ;
      return 0;
}
      溢出后,b = 258 % 256 = 2,最后显示结果
a = 0 , b = 2

淡笑无痕丶 发表于 2020-2-19 18:17:00

jackz007 发表于 2020-2-19 14:37
char 最大只能表达到 127,即便是 unsigned char 最大也只能表达到 255,根本无法表达 258。所以, ...

不不不 老师就是我写的这个代码 老师用的GCC 我用的vs2019 不知道为什么结果还不相同 我就想了解一下原理

jackz007 发表于 2020-2-19 18:58:39

淡笑无痕丶 发表于 2020-2-19 18:17
不不不 老师就是我写的这个代码 老师用的GCC 我用的vs2019 不知道为什么结果还不相同 我就想了解一下原理

      如果这样的话,程序输出 0 , 2 就是正确的呀,你所预期的输出的结果或者,小甲鱼的答案是什么?

淡笑无痕丶 发表于 2020-2-20 20:56:41

jackz007 发表于 2020-2-19 18:58
如果这样的话,程序输出 0 , 2 就是正确的呀,你所预期的输出的结果或者,小甲鱼的答案是什么?

他的答案是1和2,编译器是gcc,系统是centOS

jackz007 发表于 2020-2-20 21:40:43

本帖最后由 jackz007 于 2020-2-20 21:42 编辑

淡笑无痕丶 发表于 2020-2-20 20:56
他的答案是1和2,编译器是gcc,系统是centOS

       在 Windows 平台上要想看到 1 , 2 这样的结果,代码得改成下面这样才行:
#include <stdio.h>

int main(void)
{
      char a = {0}               ;
      int * p = (int *) a             ;
      * p = 258                     ;
      printf("%d , %d" , a , a) ;
}

淡笑无痕丶 发表于 2020-2-21 00:02:41

原理是什么呢?
为什么他们的输出会不相同?是他们的内存分配方式不同吗?是Windows平台下只有数组才会是连续的内存地址吗?
页: [1]
查看完整版本: SIE39视频最后一段的代码运行结果不相同