比如以下語句:
char *p = “hello”;/*表示式為什麼是合法的,而把p換成陣列,然後再賦值就不行呢?*/
這是因為在C語言中,字串常量出現在一個表示式中時,表示式使用的值就是這些字串所儲存的地址(在常量區),而不是這些字元本身。比如上邊語句中的"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雖然也有地址,但是這與指標是不一樣的,指標的值是地址,而陣列的值雖然也是地址,但是卻是一個常量,所以不能給常量賦值。
比如以下語句:
char *p = “hello”;/*表示式為什麼是合法的,而把p換成陣列,然後再賦值就不行呢?*/
這是因為在C語言中,字串常量出現在一個表示式中時,表示式使用的值就是這些字串所儲存的地址(在常量區),而不是這些字元本身。比如上邊語句中的"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雖然也有地址,但是這與指標是不一樣的,指標的值是地址,而陣列的值雖然也是地址,但是卻是一個常量,所以不能給常量賦值。