C語(yǔ)言字符串?dāng)?shù)組詳解
C語(yǔ)言字符串?dāng)?shù)組
字符串是連續(xù)的字符序列,最后以空字符'\0'作為終止符。一個(gè)字符串的長(zhǎng)度指所有字符的數(shù)量,但不包括終止符。在 C 語(yǔ)言中,沒(méi)有字符串類(lèi)型,自然也就沒(méi)有運(yùn)算符以字符串為操作數(shù)。
字符串被存儲(chǔ)在元素類(lèi)型為 char 或?qū)捵址?lèi)型數(shù)組中(寬字符類(lèi)型指 wchar_t、char16_t 或 char32_t)。寬字符組成的字符串也稱(chēng)為寬字符串(wide string)。
C 標(biāo)準(zhǔn)庫(kù)提供了大量的函數(shù),它們可以對(duì)字符串進(jìn)行基本操作,例如字符串的比較、復(fù)制和連接等。在這些傳統(tǒng)的字符串函數(shù)以外,C11 新增了這些函數(shù)的“安全”版本,它們能確保字符串操作不會(huì)超出數(shù)組的邊界。
可以使用字符串字面量來(lái)初始化任何字符類(lèi)型數(shù)組。例如,下面兩個(gè)數(shù)組的定義是等價(jià)的:
char str1[30] = "Let's go"; // 字符串長(zhǎng)度:8;數(shù)組長(zhǎng)度:30 char str1[30] = { 'L', 'e', 't', '\'', 's',' ', 'g', 'o', '\0' };
存儲(chǔ)字符串的數(shù)組一定比字符串長(zhǎng)度多一個(gè)元素,以容納下字符串終止符(空字符'\0')。因此,str1 數(shù)組能夠存儲(chǔ)的字符串最大長(zhǎng)度是 29。如果定義數(shù)組長(zhǎng)度為 8,而不是 30,就會(huì)發(fā)生錯(cuò)誤,因?yàn)樗鼰o(wú)法包含字符串終止符。
如果在定義一個(gè)字符數(shù)組時(shí),沒(méi)有顯式地指定長(zhǎng)度,但使用了字符串字面量來(lái)對(duì)它進(jìn)行初始化,該數(shù)組的長(zhǎng)度會(huì)比字符串長(zhǎng)度多 1。如下列所示:
char str2[] = " to London!"; // 字符串長(zhǎng)度:11 (注意開(kāi)頭的空格); // 數(shù)組長(zhǎng)度:12
下面的語(yǔ)句使用標(biāo)準(zhǔn)函數(shù) strcat()把字符串 str2 附加到字符串 str1 的后面(str1 數(shù)組長(zhǎng)度必須足夠大以容納連接后的全部字符)。
#include <string.h> char str1[30] = "Let's go"; char str2[ ] = " to London!"; /* ... */ strcat( str1, str2 ); puts( str1 );
調(diào)用 puts()后,輸出新的 str1 數(shù)組內(nèi)容:
Let's go to London!
str1 和 str2 的名字其實(shí)是兩個(gè)指針,它們指向各自數(shù)組的第一個(gè)字符。這樣的指針被稱(chēng)為指向字符串的指針(pointer to a string),或者簡(jiǎn)稱(chēng)為字符串指針(string pointer)。
字符串處理函數(shù)(例如 scrcat()和 puts())需要接收字符串起始地址并將其作為參數(shù)。這樣的函數(shù)通常逐個(gè)字符地處理字符串,直到遇到結(jié)尾終止符'\0'為止。
例 1 是函數(shù) strcat()的另——種可能的實(shí)現(xiàn)方式。它采用從函數(shù)參數(shù)傳入的指針遍歷處理整個(gè)字符串。 【例1】函數(shù) strcat()
// 函數(shù)strcat() 將第二個(gè)字符串復(fù)制一份并附加到第一個(gè)字符串的尾部 // 參數(shù):指向兩個(gè)字符串的指針 // 返回值:指向第一個(gè)字符串的指針,此時(shí)已將第二個(gè)字符串連接到了其尾部 char *strcat( char * restrict s1, const char * restrict s2 ) { char *rtnPtr = s1; while ( *s1 != '\0' ) // 找到字符串s1的尾部 ++s1; while (( *s1++ = *s2++ ) != '\0' ) // 將s2的首字符替換掉s1的終止符 ; return rtnPtr; }
以 s1 地址為起始位置的 char 數(shù)組,其長(zhǎng)度至少是兩個(gè)字符串長(zhǎng)度的和再加上 1,以容納字符串終止符。在調(diào)用 strcat()之前,可以采用標(biāo)準(zhǔn)函數(shù) strlen()進(jìn)行測(cè)試,以確保長(zhǎng)度沒(méi)有問(wèn)題,函數(shù) strlen()返回其字符串參數(shù)的長(zhǎng)度,如下所示:
if ( sizeof(str1) >= ( strlen( str1 ) + strlen( str2 ) + 1 ) ) strcat( str1, str2 );
寬字符串字面量會(huì)加上一個(gè)前綴 L、u 或 U,它們是寬字符串的標(biāo)志。因此,wchar_t 數(shù)組的初始化過(guò)程如下所示:
#include <stddef.h> // 定義wchart_t類(lèi)型 /* ... */ wchar_t dinner[] = L"chop suey"; // 字符串長(zhǎng)度:10; // 數(shù)組長(zhǎng)度:11; // 數(shù)組空間大?。?1 * sizeof(wchar_t)
到此這篇關(guān)于C語(yǔ)言字符串?dāng)?shù)組詳解的文章就介紹到這了,更多相關(guān)C語(yǔ)言字符串?dāng)?shù)組內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言實(shí)現(xiàn)的猴子分桃問(wèn)題算法解決方案
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)的猴子分桃問(wèn)題算法,較為詳細(xì)的分析了猴子分桃問(wèn)題算法的原理與通過(guò)遞歸算法解決問(wèn)題的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-10-10C++實(shí)現(xiàn)圖書(shū)管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)圖書(shū)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12C 語(yǔ)言編寫(xiě)一個(gè)計(jì)算器界面(可視化界面和多功能)
今天給大家分享一個(gè)計(jì)算器功能,主要功能有加法減法乘除法求余功能,用戶可以在主菜單選擇需要計(jì)算的功能,接下來(lái)根據(jù)用戶輸入的數(shù)字進(jìn)行計(jì)算輸出結(jié)果,喜歡的朋友拿去用吧2021-06-06C語(yǔ)言模擬實(shí)現(xiàn)通訊錄程序過(guò)程
這篇文章主要介紹了C語(yǔ)言模擬實(shí)現(xiàn)通訊錄程序過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-02-02