請問字元塊和字串有什麼區別,請問字串和字元陣列的區別是什麼

2021-03-04 06:08:14 字數 3746 閱讀 9388

1樓:司馬鑄劍

字元型別只有乙個字

節,就是只能儲存乙個字元,單個字母或者數字,例如a或者1,字元型別的賦值應該用' '號。例如 char a='a';就是將字母a賦給變數a。

字串可以儲存多個字元,例如儲存一句"i am fine"等。字串的賦值要用" ";string a="i am fine!"就是將i am fine!

這個字串賦給字串變數。值得注意的是字串變數會在最後加多乙個結束標誌'\0'。例如char a='a',佔乙個位元組,而string a="a"則佔兩個位元組,因為除了儲存字母a外還要儲存'\0'這標誌。

所以char a="a"這個語句是不對的,因為變數a只佔乙個位元組,而"a"則佔兩個位元組,所以上述賦值表示式是非法的。不知道我這麼說能不能讓樓主明白呢?

請問字串和字元陣列的區別是什麼?

2樓:a羅網天下

區別一:定義不一樣

1、字串指標變數本身是乙個變數,用於存放字串的首位址。字串本身是存放在以該首位址為首的一塊連續的記憶體空間中並以『\0』作為串的結束。

2、字元陣列是由於若干個陣列元素組成的,它可用來存放整個字串。

區別二:對字串指標方式不同

1、char *ps=」c language」;可以寫成char *ps;ps=」c language」;

2、陣列方式char st=;不能寫成char st[20];

st=;只能對字元陣列的各元素逐個賦值。

字串主要用於程式設計,概念說明、函式解釋、用法詳述見正文,這裡補充一點:字串在儲存上類似字元陣列,所以它每一位的單個元素都是可以提取的。

如s=「abcdefghij」,則s[1]=「b」,s[9]="j",而字串的零位正是它的長度,如s[0]=10(※上述功能ansistring沒有。),這可以給我們提供很多方便,如高精度運算時每一位都可以轉化為數字存入陣列。

字串資料型別是建模在形式字串的想法上的資料型別。字串是幾乎在所有程式語言中可以實現的非常重要和有用的資料型別。在某些語言中它們可作為基本型別獲得,在另一些語言中做為復合型別獲得。

多數高階語言的語法允許通常用某種方式引用起來的字串來表示字串資料型別的例項;這種元字串叫做「文字」或「字串文字」。

3樓:匿名使用者

1、結束標誌不同

字串:必須以'\0'結尾;//  『 \0 』 的意義是「字串結束符」。

字元陣列:可以包含多個'\0',但是如果當做字串處理,則實際有效字串為第乙個'\0'的簽名的字串,如果當做字元陣列處理,可以處理字元陣列的任何乙個字元,所有的字元都可以是'\0'。

2、特點不同

字串在儲存上類似字元陣列,所以它每一位的單個元素都是可以提取的,如s=「abcdefghij」,則s[1]=「b」,s[9]="j"。

而字串的零位正是它的長度,如s[0]=10(※上述功能ansistring沒有。),這可以給我們提供很多方便,如高精度運算時每一位都可以轉化為數字存入陣列。

字元陣列是指用來存放字元資料的陣列。其定義的一般形式為: char 陣列名[資料長度] 。

字元陣列用於存放字元或字串,字元陣列中的乙個元素存放乙個字元,它在記憶體中佔用乙個位元組。c語言中沒有字串型別,字串是存放在字元型陣列中的。

4樓:莫扣曲

贊同以上的網友說的處理方式不同,我來完善一下。

一、字串

"abc"//這是乙個字串常量(也叫字串字面量)

上面的例子就是乙個字串,看似其有3個字元,實際上的處理是4個字元,包括c後面的'\0'字元也就是空字元null。編譯器遇到空字元就結束處理了。

在程式設計中也可以把字串放到字串陣列當中處理:

char str1 = "abc";//編譯器會自動計算字串的長度

char str2[20] = "abc";//這是乙個字串陣列

用雙引號括起來的內容被視為指向該字串儲存位置的指標,類似於把陣列名作為指向該陣列位置的指標。

也可以這樣初始化乙個字串陣列:

char str3 [4] = ;//字串的陣列的長度要確保比字串長度多1以便為了容納'\0'

注意:沒有最後的空字元,這就不是乙個字串,而是乙個字元陣列,所有未被初始化的元素都被自動初始化為空字元'\0'。

不要這樣初始化字串陣列:

char dont = ;

這樣編譯器會不知道從**停止,直到找到記憶體中最近的乙個空字元,好在記憶體中空字元很多,不會花費太長時間。

二、字元陣列

字元陣列與字串陣列的最大區別是處理範圍不同,字串陣列遇到空字元便結束,而字元陣列可以根據程式設計者的需要控制處理的長度。但是和字串陣列一樣的是,字元陣列的最後乙個字元也一定是空字元,如下的初始化無法通過編譯:

char str4 [1] = ;//錯誤:初始值設定太多

宣告陣列時(包含字元陣列),陣列大小必須是可求值的整數。在c99新增變長陣列之前,陣列的大小必須是整型常量,包括由整型常量組成的表示式。

int n = 8;

char str5[2*sizeof(int)+1];//有效

char str6[n];//c99後有效的變長陣列

在不越界的情況下,開發者可以根據需要程式設計處理字元陣列。

與處理字串不同,碰到空字元編譯器會繼續處理空字元後面的資料。

例如:char str7 [3] = ;

str7[1] = 'b';

5樓:不懂多來問問

區別嗎 字串有結束符,字元陣列沒有結束符(自己可以加上,如果是用系統函式輸入的,系統會自動加)。總的來說是沒有區別的,字串就是以字元陣列形式儲存的。你可以把乙個字串看成是乙個字元陣列,可以按陣列那樣操作。

兩者沒有本質的區別,只是在不同的情況下有不同的叫法。

樓下說的字串類,其實就是對字串的封裝,加上了一些對字串的操作方法,其內部字串的儲存格式在本質上沒有改變,就像資料結構一樣,字串的儲存可以有很多種(像陣列,連結串列,如果可以用樹結構也沒關係),然後再加上一組對字串結構的操作函式。所以從陣列結構來說,字串和字元陣列沒有本質上的區別,如果是連結串列或其它結構,也可以做到在最上層的操作是一樣,至於低層的結構,完全可以對使用者 無關。

6樓:匿名使用者

了解不多。二者裝載有樣多字元時,用函式strlen()返回的長度不同,且字串的長度比字元陣列長度大1。這是因為在初始化時,字串是以指標標記其起始位址,而陣列則以陣列名標記的,陣列名是常量,不像指標那樣可以使用++或--使其指向不同位置的字元。

作為實參傳遞給函式時,無論是字元陣列,還是字串,一律以指標方式傳遞,這個指標包含字串的首位址,且字串的末尾加上串結束符'\0',所以,無論呼叫strcpy()函式,還是strcat()等其他任何函式,字元陣列和字串的呼叫沒有任何區別。

7樓:匿名使用者

字串:必須以'\0'結尾

字元陣列:可以包含多個'\0',但是如果當做字串處理,則實際有效字串為第乙個'\0'的簽名的字串,如果當做字元陣列處理,可以處理字元陣列的任何乙個字元,所有的字元都可以是'\0'

假設乙個字元指標指向字串「aaaaaa」,如果通過指標下標是第三個a為'\0',則字元指標就只有三個長度,如果你的下標超過3則越界,字元陣列只要不超過陣列大小就不越界

8樓:匿名使用者

java 的字串是存在stringpool裡面的,字元陣列有自己單獨的空間,並且字串如果要去裡面的字元要用乙個函式,類似charat,字元陣列取下標就可以取

位元組數,字串長度,字元個數有哪些區別

對於大多數程式設計開發者抄來說,當計算字bai符串的長度時,du腦海中閃現的第乙個函式,默zhi認情況下dao,是指字元的數量,乙個英語字元是乙個長度,乙個漢字是乙個長度。大多數的字串函式,其位置都是針對字元數量的,這使得len函式深入人心,但是,乙個unicode字元,佔用的位元組數量是2byte...

c語言裡面的字串常量和字元常量有什麼區別

字串常量是乙個或多個字元組成的常量 比方說 乙個字串常量a 給它的初始值是 abc123 可以是乙個字元 5 構成 但是字元常量只能是乙個字元 比方說乙個字元常量 a 它的初始值為 1 不能多於乙個字元的 字串是以 0結束的 而字元常量是沒有的 字串常量和字元常量有什麼區別就是多個字元和單個字元的區...

c中字串為什麼有兩種形式,c中字串為什麼有兩種形式?cstyle和string有什麼區別?

c style 是乙個指標,或者char陣列,字串的末尾有 0字元 string是乙個stl中的類,用於處理字串,string有乙個方法可以返回乙個c style指標 string中還包含了很多處理字串需要的方法,一般不最強最快效率的情況下用string不容易出錯 c style 是最原始的,位元組...