char a[] = "hello world1"和char *p = "hello world2";的区别(转)
转自:jianchi88 http://blog.csdn.net/jianchi88/article/details/6876405
#include<stdio.h> int main() { char a[] = "hello world1"; char *p = "hello world2"; *(a+1)='q'; *(p+1)='q'; printf("%s\n",a); printf("%s\n",p); }
运行结果
段错误。
注释 *(p+1)='q';
运行结果
hqllo world1
hello world2
原因:
一、a与p类型不同:p为指向字符串的指针;a为保存字符串的数组。
char a[] = "hello world1"; 是个赋初值的字符数组。
char *p = "hello world2"; 是个字符串常量指针;
指针变量p在栈里面
字符串常量"hello world2"在全局数据区,数据段,只读,不可写
二、"hello world2"和"hello world1"字符串保存的位置不同。"hello world1"保存在栈
中,可用*(a+1)='q'修改,"hello world2"保存在全局数据
区,位置是在.rodata中,不能修改*(p+1)='q'
三、只有2中情况下,数组名不可等同视为数组指针,&与sizeof操作符
“&”的区别:
&p取得是指针变量的地址,而非字符串"hello world2"的首地址,p指向字符串的首地址;&a取得
就是字符串"hello"的首地址。
“siziof”的区别:
下面假设在ia32平台上运行,保存变量的内存空间不同。
sizeof(p); // return 4, pointer size
sizeof(a); // return 13, array size
5 char a[] = "hello world1"; (gdb) p a $1 = "\000<\006�\005�?�"//空 (gdb) s 6 char *p = "hello world2"; (gdb) p a $2 = "hello world1" (gdb) p &a $3 = (char (*)[13]) 0xbfde0583 //在栈 (gdb) s 7 *(a+1)='q'; (gdb) p p $4 = 0x80484c0 "hello world2" //在数据段 (gdb) p &p $5 = (char **) 0xbfde0590 //在栈
————————————————————————————————————————————————————————————————————————————————————————————
面试题知识点:
当指针赋值给相同的常量字符串时,它们实际上会指向相同的内存地址,但是常量内存初始化数组,情况确不一样。
char str1[] = "hello world"; char str2[] = "hello world"; string* str3 = "hello world"; string* str4 = "hello world"; 问str1 == str2是否成立?str3 == str4是否成立? (提示,前一个不成立,后一个成立)
char a[] = "hello world"; char b[] = "hello world"; char *str1="hello world"; char *str2="hello world"; 前两个不同,后两个相同,即a!=b;str1==str2;