1. 程式人生 > >字符串賦值給字符指針變量

字符串賦值給字符指針變量

字符數 修改 運行時異常 首地址 變量 使用 abc 語句 amp

char *p,a=‘5‘;

p=&a; //顯然是正確的,
p="abcd"; //但為什麽也可以這樣賦值??

雙引號做了3件事: 1.申請了空間(在常量區),存放了字符串
2. 在字符串尾加上了‘/0‘
3.返回地址

這裏就是 返回的地址 賦值給了 p

char *p = “hello”;

把p換成數組,然後再賦值就不行

字符串常量"hello"出現在一個表達式中時,"hello"表達式使用的值就是這些字符所存儲的地址(在常量區),而不是這些字符本身。

所以,可以把字符串賦值給指向字符的指針p,而不能把字符串賦值給一個字符數組。

char a[10] = “hello”; //這樣可以,這種情況是c語言初始化所支持的

如果寫成char a[10]

然後 a = “hello” 這樣就錯誤了。

同樣是a數組,char a[10] = “hello”;這種是數組的初始化,和a[0] = ‘h’ a[1] = ‘e’…是一個道理

但是換成char a [10]

然後a = “hello”就不行了 “hello”賦值的值是一個地址,而a雖然也有地址,但是這與指針是不一樣

的,指針的值是地址,而數組的值雖然也是地址,但是卻是一個常量,所以不能給常量賦值。

以字符串形式出現的,編譯器都會為該字符串自動添加一個0作為結束符,如在代碼中寫
"abc",那麽編譯器幫你存儲的是"abc\0"

"abc"是常量嗎?有時是,有時不是。

不是常量的情況:"abc"作為字符數組初始值的時候就不是,如

char str[] = "abc";
因為定義的是一個字符數組,所以就相當於定義了一些空間來存放"abc",而又因為
字符數組就是把字符一個一個地存放的,所以編譯器把這個語句解析為
char str[3] = {‘a‘,‘b‘,‘c‘};
又根據上面的總結1,所以char str[] = "abc";的最終結果是
char str[4] = {‘a‘,‘b‘,‘c‘,‘\0‘};
做一下擴展,如果char str[] = "abc";是在函數內部寫的話,那麽這裏
的"abc\0"因為不是常量,所以應該被放在棧上。

是常量的情況: 把"abc"賦給一個字符指針變量時,如
char* ptr = "abc";
因為定義的是一個普通字符指針,並沒有定義空間來存放"abc",所以編譯器得幫我們
找地方來放"abc",顯然,把這裏的"abc"當成常量並把它放到程序的常量區是編譯器
最合適的選擇。所以盡管ptr的類型不是const char*,並且ptr[0] = ‘x‘;也能編譯
通過,但是執行ptr[0] = ‘x‘;就會發生運行時異常,因為這個語句試圖去修改程序
常量區中的東西。
如果char* ptr = "abc";寫在函數體內,那麽雖然這裏的"abc\0"被放在常量區中,
但是ptr本身只是一個普通的指針變量,所以ptr是被放在棧上的,只不過是它
所指向的東西被放在常量區罷了。

數組的類型是由該數組所存放的東西的類型以及數組本身的大小決定的。
如char s1[3]和char s2[4],s1的類型就是char[3],s2的類型就是char[4],
也就是說盡管s1和s2都是字符數組,但兩者的類型卻是不同的。

對於char str[] = "abcdef";就有sizeof(str) == 7,因為str的類型是char[7],
也有sizeof("abcdef") == 7,因為"abcdef"的類型是const char[7]。
對於char *ptr = "abcdef";就有sizeof(ptr) == 4,因為ptr的類型是char*。
對於char str2[10] = "abcdef";就有sizeof(str2) == 10,

因為str2的類型是char[10]。
對於void func(char sa[100],int ia[20],char *p);就有sizeof(sa) == sizeof(ia) == sizeof(p) == 4,
因為sa的類型是char*, ia的類型是int*,p的類型是char*。

char *s1=“string1”;//定義字符串常量,指針形式

char s2[]=“string2”;//定義字符串常量,數組形式

char *s3=new char[10];//定義字符串變量並分配內存 指針形式

strcpy(s3,"string3");//為s3賦值

char s4[10];//定義字符串變量,數組形式

strcpy(s4,"string4");//為s4賦值

以上方法都能定義一個字符串,同時通過字符串在內存中的分布可以清楚地知道是什麽情況

C語言中字符串賦值方法strcpy(char*d,char*s)其中s代表是源字符串,d代表目標字符串,也就是要賦值的字符串。

在c語言中,比如char *p,其中p是一個指針,p中存儲一個內存緩沖區的首地址。所謂的內存緩沖區就是一段
連續的內存地址,裏面存放了一系列的字符。那系統又是如何判斷在哪裏結束呢。那就是根據符號‘\0’。這個
字符占一個字節,8位,每位的值都是0。

字符串賦值給字符指針變量