c - 在 C 中,为什么不能像将字符串值分配给 char* 一样将整数值分配给 int*?

标签 c pointers char int

我一直在浏览网站,但还没有找到这个问题的答案。

用一个例子来解释这个问题是最简单的(至少对我而言)。

我不明白为什么这是有效的:

#include <stdio.h>

int main(int argc, char* argv[])
{
  char *mystr = "hello";
}

但这会产生一个编译器警告(“初始化从整数生成指针而不进行强制转换”):

#include <stdio.h>

int main(int argc, char* argv[])
{
  int *myint = 5;
}

我对第一个程序的理解是,它创建了一个名为 mystr 的变量,类型为 pointer-to-char,其值是字符串文字“hello”的第一个字符 ('h') 的地址。换句话说,通过此初始化,您不仅可以获取指针,还可以定义指针指向的对象(在本例中为“hello”)。

那么,为什么 int *myint = 5; 似乎没有实现与此类似的东西,即创建一个类型为 pointer-to-int 的名为 myint 的变量,其值是地址值'5'?为什么这个初始化既不给我指针又不定义指针指向的对象?

最佳答案

事实上,您可以使用复合文字,这是 1999 年 ISO C 标准添加到语言中的一项功能。

字符串文字的类型为 char[N],其中 N 是字符串的长度加 1。与任何数组表达式一样,它被隐式转换,在大多数但不是所有情况下,指向数组第一个元素的指针。所以这个:

char *mystr = "hello";

将内容为"hello" 的数组的初始元素的地址分配给指针mystr(后跟终止符'\0' 空字符)。 顺便说一句,这样写更安全:

const char *mystr = "hello";

整数没有这样的隐式转换——但你可以这样做:

int *ptr = &(int){42};

(int){42} 是一个复合文字,它创建一个初始化为 42 的匿名 int 对象; & 获取该对象的地址。

但要注意:由字符串文字创建的数组始终具有静态存储持续时间,但由复合文字创建的对象可以具有静态或自动存储持续时间,具体取决于它出现的位置。这意味着如果 ptr 的值从函数返回,则具有值 42 的对象将不复存在,而指针仍指向它。

至于:

int *myint = 5;

尝试将值 5 分配给 int* 类型的对象。 (严格来说是初始化而不是赋值,但是效果是一样的)。由于没有从 intint* 的隐式转换(除了 0 被视为空指针常量的特殊情况),这是无效。

关于c - 在 C 中,为什么不能像将字符串值分配给 char* 一样将整数值分配给 int*?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31548263/

相关文章:

c - 创建新函数时收到错误消息

c - 从函数返回后如何实现堆栈框架不被销毁?

c - 将静态结构添加到作为函数参数的数组

C++、指针、引用、从一个函数传递到另一个函数、std::vector、std::string

c - C中的字符串文字真的不可修改吗?

c - 将指针传递给 C 过程中的指针

c++ - 如何使用 fprintf/printf 打印破折号或点?

java - JAVA中一个对象如何指向许多其他对象?

计算 C 中 char 数组的离散值

c - 当 actual 和 extern 类型不同时会发生什么?