C++指针初始化总结
1.字符指針的初始化
在c語言中 "string"保存的就是首個字符所在的地址? 所以可以把 字符串常量"string" 賦值給指針 char *p;?
char *s ="123456";p="string"? 但不能把字符串常量直接賦給數(shù)組,
char ch1[10]; ch1="123456";需要用到 strcpy。
strcpy_s(ch1,"123456");//VS2012用strcpy_s才過,是strcpy的安全版本但可以對數(shù)組初始化為字符串,也就是字符數(shù)組。如? char str[] = "string";?
兩種初始化的區(qū)別:
char * p="the fine day" ; char str[]="the fine day"不同, 這兩個都是給字符串的初始化,前者只是把字符串的首地址給str,沒有分配足夠的內(nèi)存地址來保存整個字符串 , 后者初始化的同時,把他們保存在數(shù)組中,也就是分配好了所有字符需要的內(nèi)存。 所以:
(1) char *p = "string"; // 地址變量p 保存的是 's' 的地址,, (2) char str[] = "the fine day"; //字符數(shù)組str保存的是整個字符串,某些情況下退化為指針 (3) char *str1 = "the day"; // OK.此時,如果要復(fù)制另一個字符串str1 到p或str:
strcpy(p, str1); //錯誤! 需改為 p=(char*)malloc( strlen(str1)+1 ); 才正確 strcpy(str, str1); //沒錯誤,已有足夠內(nèi)存,但不能總是保證。 strncpy(str, str1, strlen(str) ); //正確!不作討論實(shí)際上,(1)中是不對的,好像新標(biāo)準(zhǔn)已經(jīng)會報錯;
通常應(yīng)該這樣初始化:strcpy(p, "string");
或者改為:const *p = ""string";? 但這樣就不能修改p了。
針對這個分配的內(nèi)存空間可能不足導(dǎo)致溢出的不安全問題,已經(jīng)出了一個新的版本strcpy_s。具體參考其他日志。
另外補(bǔ)充一點(diǎn),這樣初始化時錯誤的
char *p ='a';//指針只能保存地址,不是保存值(字符a)2.整形指針的初始化
試看下面語句哪一行 能夠 打印輸出?
int a = 10; int * p1 = 0; int * p2 = &a; //常見,初始化為某變量的地址 int * p3 = 20; printf("p1=%p, *p1=%d\n", p1, *p1); printf("p2=%p, *p2=%d\n", p2, *p2); printf("p3=%p, *p3=%d\n", p3, *p3);這幾行語句編譯時會有警告:p3那一行將整數(shù)賦值給指針,沒做類型轉(zhuǎn)換。
運(yùn)行時會導(dǎo)致崩潰。
為什么呢?
仔細(xì)看一下,int * p1 = 0;???? //真的初始化了嗎?
???????????????????? int * p3 = 20;??? // *p3 初始化成20了嗎?
其實(shí)int *p1 = 0 相當(dāng)于 int *p1 = NULL,不能讀取空指針 p1 以及 *p1 的值!,編譯不會報錯,但是運(yùn)行時會報異常。
而 int *p3 = 20 相當(dāng)于 int *p3;?? p3 = (int *)0x00000014; 不能讀取*p3的值。
轉(zhuǎn)載于:https://www.cnblogs.com/VIPler/p/4319313.html
總結(jié)
以上是生活随笔為你收集整理的C++指针初始化总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: spring处理方法返回值的类型
- 下一篇: 测试 Zoundry Raven