分類專欄: c語言
char *s定義了乙個char型的指標,它只知道所指向的記憶體單元,並不知道這個記憶體單元有多大,所以:
當char *s = 「hello」;後,不能使用s[0]=『a』;語句進行賦值。這是將提示記憶體不能為"written"。
當用char s=「hello」;後,完全可以使用s[0]=『a』;進行賦值,這是常規的陣列操作。
若定義:
1char s = "
hello";
2char *p = s;
也可以使用p[0] = 『a』;因為這是p ==s,都是指向陣列的指標。
1char *s = (char *)malloc(n);//
其中n為要開闢空間的大小
相當於
1char s[n];
1 #include 2int main(int argc, char*ar**) {
3char* buf1 = "
abcd1234";
4char buf2 = "
abcd1234";
5 printf("
size of buf1: %d\n
", sizeof
(buf1));
6 printf("
size of buf2: %d\n
", sizeof
(buf2));
7 printf("
長度為:%d %d\n
", strlen(buf1), strlen(buf2));
8return
0;
size of buf1: 4size of buf2: 9
長度為:8 8
C語言中char 和 char 區別
原文 c語言中char 和 char 區別 想要把丟掉的東西撿起來,還是很辛苦啊,今天我就發現,我連char 和 char 的區別都不知道。很多人覺得這兩個定義效果一樣,其實差別很大。以下是個人的一些看法,有不正確的地方望指正。本質上來說,char s定義了乙個char型的指標,它只知道所指向的記憶...
C語言上char 及char 用法區別比較
一般來說,很多人會覺得這兩個定義效果一樣,其實差別很大。以下是個人的一些看法,有不正確的地方望指正。本質上來說,char s定義了乙個char型的指標,它只知道所指向的記憶體單元,並不知道這個記憶體單元有多大,所以 當char s hello 後,不能使用s 0 a 語句進行賦值。這是將提示記憶體不...
C語言中char 和 char 的區別
在實習過程中發現了乙個以前一直預設的錯誤,同樣char c abc 和char c abc 前者改變其內容程式是會崩潰的,而後者完全正確。程式演示 首先要搞清楚編譯程式占用的記憶體的分割槽形式 乙個由c c 編譯的程式占用的記憶體分為以下幾個部分 1 棧區 stack 由編譯器自動分配釋放,存放函式...