int i=10;
char *ptr = &i;
printf("%d",*ptr); // what will be the output and why
*ptr =11; //now what will be the output and why
谁能帮我解决这个问题?我得到不同的输出,但我不知道为什么。谁能解释一下这里发生了什么以及为什么?
最佳答案
让我们稍微分解一下。
int i = 10;
我们现在有一个变量 i
,其中包含 10。这个变量有几个字节长——为了便于论证(并且因为它是最常见的值),我们假设为 4。 10 适合一个字节,因此最低有效字节为 10,其余字节为零。但最低有效字节可以是第一个(小端字节序)或最后一个(大端字节序)——这是由编译器、底层 CPU 等定义的。
char * ptr = &i;
...是一个错误,或者至少是一个警告。让我们修复它:
char * ptr = (char *) &i;
通常,使用错误类型的指针是未定义行为,这意味着编译器可以发出任何它想要的代码。但 char
有一个异常(exception) - 您可以合法地将任何对象指针转换为 char *
(或 signed char *
或 unsigned char *
)。因此,ptr
现在指向 i
的第一个字节。
printf("%d", *ptr);
...不正确。 *ptr
的类型为 char
,但 %d
用于 int
。让我们修复它:
printf("%hhd", *ptr);
现在,记住ptr
指向i
的第一个字节。另请记住,i
有一个等于 10 的字节和几个等于 0 的字节,并且 10 可以是第一个或最后一个。所以这会打印 10 或 0。哪一个?它是实现定义的。
*ptr = 11;
如果上一行打印 10,则第一个字节是最低有效字节 - 您只需将其设置为 11,使 i
等于 11。
如果上一行打印零,则只需将最高有效字节设置为 11。这会将 i
设置为某个非常大的值。
关于指向 int 变量的 Char 指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55208025/