C语言指针
为甚么int *p = 10就算野指针,但是char *p = “xiexie”就不算野指针?不都是定义了指针但没有给地址的情况吗? 第一个int *p=10我有点不懂你什么意思,p应该指的是地址而不是值第二个char *p = “xiexie”,C语言的字符串为数组形式,而数组的名称可以表示其地址。而单独的字符、整型变量等的名称不能直接表示地址,你可以理解“”是地址的意思 https://img-blog.csdn.net/20180613145002480
这是网上找的一个内存地址分配的图,内存的四个区域:代码区、常量区、堆、栈
你从图中也不难发现,地址越低,也就是数字越小的地方,可能是代码区,这个地方不是让你读写操作的区域
但是
你再看你提供的例子:
int *p = 10
亲,请注意,你是指针=10,也是指向0x0A位置的上的值,你觉得这个值你能随便修改吗?
不能随便改而你想改,所以才很野。
我们常见的是使用堆、栈上的内存空间, 本帖最后由 jackz007 于 2020-3-8 00:04 编辑
int * p = 10 ; 是把一个整型数赋值给一个指针,意图当然是使指针 p 的值是 10,要知道,内存中 10 这个地址根本就不能访问,所以,即便代码能编译过去,运行的时候,只要涉及到 p 指针的存取操作会使程序立即奔溃。
char * p = "xiexie" 就不同了,"xiexie" 是个字符串,这个字符串本身表达的就是一个内存地址,也就是说,是一个指针,所以,这个赋值没有任何问题。
楼上说得没错。
不过不知道你是从哪看来说这个叫野指针
int *p=10; 这里的10指的是 内存地址10 ,指针p指向了内存地址为10的地方。
int main(void)
{
int a = 10;
int *p = &a;
printf("%d", *p);
return 0;
}
char *p = “xiexie” ; 字符串常量是编译时就存入在常量区了,加载入内存有了对应的地址;这句的意思自然就是p指向"xiexie"这个字符串的地址
页:
[1]