自己博客上的文章
10年積累的成都做網(wǎng)站、網(wǎng)站制作經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站設(shè)計后付款的網(wǎng)站建設(shè)流程,更有秦安免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
很多人對學(xué)習(xí)C語言感到無從下手,經(jīng)常問我同一個問題:究竟怎樣學(xué)習(xí)C語言?我是一個教師,已經(jīng)開發(fā)了很多年的程序,和很多剛剛起步的人一樣,學(xué)習(xí)的第一個計算機(jī)語言就是C語言。經(jīng)過這些年的開發(fā),我深深的體會到C語言對于一個程序設(shè)計人員多么的重要,如果不懂C語言,你想寫底層程序這幾乎聽起來很可笑,不懂C語言,你想寫出優(yōu)秀高效的程序,這簡直就是天方夜譚。為什么C語言如此重要呢?
第一:C語言語法結(jié)構(gòu)很簡潔精妙,寫出的程序也很高效,很便于描述算法,大多數(shù)的程序員愿意使用C語言去描述算法本身,所以,如果你想在程序設(shè)計方面有所建樹,就必須去學(xué)它。
第二:C語言能夠讓你深入系統(tǒng)底層,你知道的操作系統(tǒng),哪一個不是C語言寫的?所有的windows,Unix,Linux,Mac,os/2,沒有一個里外的,如果你不懂C語言,怎么可能深入到這些操作系統(tǒng)當(dāng)中去呢?更不要說你去寫它們的內(nèi)核程序了。
第三:很多新型的語言都是衍生自C語言,C++,Java,C#,J#,perl...哪個不是呢?掌握了C語言,可以說你就掌握了很多門語言,經(jīng)過簡單的學(xué)習(xí),你就可以用這些新型的語言去開發(fā)了,這個再一次驗證了C語言是程序設(shè)計的重要基礎(chǔ)。還有啊,多說一點:即使現(xiàn)在招聘程序員,考試都是考C語言,你想加入it行業(yè),那么就一定要掌握好C語言。
那么究竟怎樣學(xué)習(xí)C語言呢?
1:工欲善其事,必先利其器
這里介紹幾個學(xué)習(xí)C語言必備的東東:
一個開發(fā)環(huán)境,例如turbo?C?2.0,這個曾經(jīng)占據(jù)了DOS時代開發(fā)程序的大半個江山。但是現(xiàn)在windows時代,用turbo?C有感覺不方面,編輯程序起來很吃力,并且拖放,更沒有函數(shù)變量自動感應(yīng)功能,查詢參考資料也不方便。建議使用Visual C++,這個東西雖然比較大塊頭,但是一旦安裝好了,用起來很方便。
一本學(xué)習(xí)教程,現(xiàn)在C語言教材多如牛毛,但推薦大家使用《C語言程序設(shè)計》譚浩強(qiáng)主編 第二版 清華大學(xué)出版社,此書編寫的很適合初學(xué)者,并且內(nèi)容也很精到。
除此以外,現(xiàn)在有很多輔助學(xué)習(xí)的軟件,畢竟現(xiàn)在是Window時代了,學(xué)習(xí)軟件多如牛毛,不象我們當(dāng)初學(xué)習(xí),只有讀書做題這么老套。我向大家推薦一個“集成學(xué)習(xí)環(huán)境(C語言)”,里邊的知識點總結(jié)和例程講解都非常好,還有題庫測試環(huán)境,據(jù)說有好幾千題,甚至還有一個windows下的trubo?C,初學(xué)者甚至不用裝其它的編譯器,就可以練習(xí)編程了,非常適合初學(xué)者。還有一個“C語言學(xué)習(xí)系統(tǒng)”軟件,不過感覺只是一個題庫系統(tǒng),如果你覺得題做的不夠,不妨也可以試試。
2:葵花寶典
學(xué)習(xí)計算機(jī)語言最好的方法是什么?答曰:讀程序。
沒錯,讀程序是學(xué)習(xí)C語言入門最快,也是最好的方法。如同我,現(xiàn)在學(xué)習(xí)新的J#,C#等其他語言,不再是抱著書本逐行啃,而是學(xué)習(xí)它們的例程。當(dāng)然,對于沒有學(xué)過任何計算機(jī)語言的初學(xué)者,最好還是先閱讀教程,學(xué)習(xí)完每一章,都要認(rèn)真體會這一章的所有概念,然后不放過這一章中提到的所有例程,然后仔細(xì)研讀程序,直到每一行都理解了,然后找?guī)讉€編程題目,最好是和例程類似的或一樣的,自己試圖寫出這段已經(jīng)讀懂的程序,不要以為例程你已經(jīng)讀懂了,你就可以寫出和它一樣的程序,絕對不一定,不相信你就試一試吧,如果寫不出來,也不要著急,回過頭來再繼續(xù)研究例程,想想自己為什么寫不出來,然后再去寫這段程序,反反復(fù)復(fù),直到你手到擒來為止,祝賀你,你快入門了。
3:登峰造極
寫程序的最高境界其實就是掌握各種解決問題的手段(數(shù)據(jù)結(jié)構(gòu))和解決問題的方法(算法)。?
是不是寫出底層程序就是程序設(shè)計高手呢?非也,寫底層程序,無非是掌握了硬件的結(jié)構(gòu),況且硬件和硬件還不一樣,要給一個芯片寫驅(qū)動程序,無非就是掌握這塊芯片的各種寄存器及其組合,然后寫值讀值,僅此而已。這不過是熟悉一些io函數(shù)罷了。
那么怎樣才算精通程序設(shè)計呢?怎樣才能精通程序設(shè)計呢?舉個例子:你面前有10個人,找出一個叫“張三”的人,你該怎么辦?第一種方法:直接對這10個人問:“誰叫張三”。第2種方法:你挨個去問“你是不是張三?”,直到問到的這個人就是張三。第三種方法:你去挨個問一個人“你認(rèn)不認(rèn)識張三,指給我看”。不要小看這個問題,你說當(dāng)然會選第一種方法,沒錯恭喜你答對了,因為這個方法最快,效率最高,但是在程序設(shè)計中找到解決問題的最優(yōu)方法和你用的手段卻是考驗一個程序員程序設(shè)計水平的重要標(biāo)志,而且是不容易達(dá)到的。剛才這個問題類似于數(shù)據(jù)結(jié)構(gòu)和算法中的:Map數(shù)據(jù)結(jié)構(gòu),窮舉查找和折半查找。所以掌握好數(shù)據(jù)結(jié)構(gòu)和一些常用算法,是登峰造極的必然之路。
?
Jimmy1224 ?
碼齡11年
關(guān)注
字符串是一種重要的數(shù)據(jù)類型,但是C語言并沒有顯式的字符串?dāng)?shù)據(jù)類型,因為字符串以字符串常量的形式出現(xiàn)或者存儲于字符數(shù)組中。字符串常量適用于那些程序不會對它們進(jìn)行修改的字符串。所有其他字符串都必須存儲于字符數(shù)組或動態(tài)分配的內(nèi)存中。本文描述處理字符串和字符的庫函數(shù),以及一些相關(guān)的,具有類似能力的,既可以處理字符串也可以處理非字符串?dāng)?shù)據(jù)的函數(shù)。
1.1 字符串基礎(chǔ)
字符串是一串零個或多個字符,并且以一個位模式全0的NUL字節(jié)('\0')結(jié)尾。NUL字節(jié)是字符串的終止符,但它本身并不是字符串的一部分,所以字符串長度并不包括NUL字節(jié)。
頭文件string.h包含了字符串函數(shù)所需的圓形和聲明。在程序中包含這個頭文件確實是個好主意,因為有了它所包含的原型,編譯器可以更好地為程序執(zhí)行錯誤檢查。
1.2字符串長度
字符串的長度是它所包含的字符個數(shù),不包含NUL字節(jié)。我們很容易對字符進(jìn)行計數(shù)來計算字符串的長度。需要說明的是,如果strlen函數(shù)的參數(shù)不是一個以NUL字節(jié)結(jié)尾的字符序列,它將繼續(xù)進(jìn)行查找,直到發(fā)現(xiàn)一個NUL字節(jié)為止,這樣strlen函數(shù)的返回值將是不確定數(shù)!
庫函數(shù)strlen的源碼如下:
size_t strlen(char const * string)
{
int length;
for (length = 0; *string++ != '\0'; ;)
{
length += 1;
}
return length;
}
注意:
strlen返回一個類型為size_t的值,它是一個無符號整數(shù)類型。在表達(dá)式中使用無符號可能導(dǎo)致不可預(yù)料的結(jié)果。
例如:
if ( strlen(x) = strlen(y) )
{
...
}
if (strlen(x) - strlen(y) = 0)
{
...
}
上面兩個表達(dá)式看似相等,但事實上它們是不想等的。第一條語句是我們所預(yù)想的那樣工作,但第2條語句的結(jié)果永遠(yuǎn)為真。因為strlen的結(jié)果是無符號,所以strlen(x)-strlen(y)的結(jié)果也是個無符號數(shù),而無符號數(shù)都是大于等于“0”的。在表達(dá)式中如果同時包含了無符號和有符號數(shù)同樣會產(chǎn)生奇怪的結(jié)果。
1.3 不受限制的字符串函數(shù)
最常用的字符串函數(shù)都是“不受限制”的,就是說它們只是通過尋找字符串參數(shù)結(jié)尾的NUL字節(jié)來判斷它們的長度。這些函數(shù)一般都指定一塊內(nèi)存用于存放結(jié)果字符串。在使用這些函數(shù)時,程序員必須保證結(jié)果字符串不會溢出這塊內(nèi)存。
1.3.1 復(fù)制字符串
用于復(fù)制字符串的函數(shù)是strcpy,它的原型如下:
char *strcpy( char *dst, char const *src);
這個函數(shù)把參數(shù)src字符串復(fù)制到dst參數(shù)。如果參數(shù)src和dst在內(nèi)存中出現(xiàn)重疊,其結(jié)果是未定義的。由于dst參數(shù)將進(jìn)行修改,所以它必須是個字符數(shù)組或者是一個指向動態(tài)分配內(nèi)存的數(shù)組指針,不能使用字符串常量。
目標(biāo)參數(shù)以前的內(nèi)容將被覆蓋丟失。即使新的字符串比dst原先的內(nèi)存更短,由于新的字符串是以NUL字節(jié)結(jié)尾,所以老字符串最后剩余的幾個字符也會被有效地刪除。需要注意的是字符結(jié)束標(biāo)志也將被復(fù)制。
例如:
char message[] = "message";
...
if (...)
{
strcpy( message, "Dif");
}
如果條件為真并且復(fù)制順利執(zhí)行,數(shù)組將包含下面的內(nèi)容:
?
第一個NUL字節(jié)后面的幾個字符再也無法被字符串函數(shù)訪問,因此從任何角度實現(xiàn)看,它們都已經(jīng)是丟失的了。
注意:
程序員必須保證目標(biāo)字符數(shù)組的空間足以容納需要復(fù)制的字符串。如果字符串比數(shù)組長,多余的字符仍被復(fù)制,它們將覆蓋原先存儲于數(shù)組后面的內(nèi)存空間的值。strcpy無法解決這個問題,因為它無法判斷目標(biāo)字符數(shù)組的長度。
1.3.2 連接字符串
strcat函數(shù)可以實現(xiàn)一個字符串添加到另一個字符串的后面。函數(shù)原型如下:
char *strcat( char *dst, char const *src);
strcat函數(shù)要求dst參數(shù)原先已經(jīng)包含一個字符串(可以是空字符串)。它找到這個字符串的末尾,并把src字符串的一份拷貝添加到這個位置。如果src和dst的位置發(fā)生重疊,其結(jié)果是未定義的。
下面是這個函數(shù)的常見用法:
strcpy( message, "hello");
strcpy( message, customer_name);
注意:程序員必須保證目標(biāo)字符數(shù)組剩余的空間足以保存整個src源字符串。
1.3.3 字符串比較
庫函數(shù)strcmp的原型如下:
int strcmp( char const *s1, char const *s2);
字符串比較的規(guī)則:
對兩個字符串自左向右逐個字符比較(按ASCII碼值大小比較),直到出現(xiàn)不同的字符或遇到‘\0’為止,如果全部相同則認(rèn)為相等。
1. s1小于s2,函數(shù)返回負(fù)整數(shù);
2. s1大于s2,函數(shù)返回正整數(shù);
3. s1等于s2,函數(shù)返回0;
注意:比較兩個字符串更好的方法是把返回值與零進(jìn)行比較。
if ( 0 == strcmp(str1,str2))
{
...
}
注意:
由于strcmp并不修改它的任一個參數(shù),所以不存在溢出字符數(shù)組的危險。strcmp函數(shù)的字符串參數(shù)也必須以一個NUL字節(jié)結(jié)尾。如果不是,strcmp就可能對參數(shù)后面的字節(jié)進(jìn)行比較,這個比較結(jié)果無意義!
1.4 長度受限的字符串函數(shù)
標(biāo)準(zhǔn)庫函數(shù)還包含了一些函數(shù),這些函數(shù)接受一個顯式的長度參數(shù),用于限定進(jìn)行復(fù)制或比較的字符數(shù)。這些函數(shù)提供了一種方便的機(jī)制,可以防止難以預(yù)料的長字符串從它們的目標(biāo)數(shù)組溢出。
這些函數(shù)的原型如下所示,和不受限制版本一樣,如果源參數(shù)和目標(biāo)參數(shù)發(fā)生重疊,strncpy和strncat的結(jié)果都是未定義。
char *strncpy(char *dst, char const *src, size_t len );
char *strncat(char *dst, char const *src, size_t len );
char *strncmp(char const *s1, char const *s2, size_t len );
1.4.1 strncpy
和strcpy一樣,strncpy把源字符串的字符復(fù)制到目標(biāo)數(shù)組。但它總是向dsr寫入len個字符。如果strlen(src)的值小于len,dst數(shù)組就用額外的NUL字節(jié)填充到len長度。如果strlen(src)的值大于或等于len,那么只有l(wèi)en個字符被復(fù)制到dst中。此時,它的結(jié)果將可能不會以NUL字節(jié)結(jié)尾。
例如:
char dst[10];
char src[] = "abcdefghijklmn";
strncpy(dst, src,5);
//dst字符數(shù)組不是以NUL結(jié)尾,len是23,是個隨機(jī)數(shù)
int len = strlen(dst);
警告:
strncpy調(diào)用的結(jié)果可能不是一個字符串,因此字符串必須是以NUL字節(jié)結(jié)尾。如果在一個需要字符串的地方(例如:strlen函數(shù)參數(shù))使用了沒有以NUL字節(jié)結(jié)尾的字符序列,會發(fā)生什么情況呢?strlen函數(shù)不知道NUL字節(jié)是沒有的,所以它將繼續(xù)一個字符一個字符的查找,知道發(fā)現(xiàn)NUL字節(jié)為止?;蛘呷绻瘮?shù)試圖訪問系統(tǒng)分配給這個程序以外的內(nèi)存范圍,程序就會崩潰。
這個問題只有當(dāng)你使用strncpy函數(shù)創(chuàng)建字符串,然后或者對它們使用str開頭的庫函數(shù),或者在printf中使用%s格式打印它們時才會發(fā)生??紤]如下代碼:
char buffer[BSIZE];
...
strncpy(buffer,name,BSIZE);
buffer[BSIZE-1] = '\0';
如果strlen(name)小于BSIZE,之后的賦值語句不起作用。但是,name長度很長,這條賦值語句可以保證buffer中的字符串是以NUL字節(jié)結(jié)尾。以后對這個數(shù)組使用strlen等其它函數(shù)就會正常工作。
1.4.2 strncat
strncat也是一個長度受限的函數(shù),但它和strncpy不同,strncat從src中最多復(fù)制len個字符到目標(biāo)數(shù)組的后面。并且,strncat總是在結(jié)果字符串后面添加一個NUL字節(jié)。它不管目標(biāo)參數(shù)除去原先存在的字符串之后留下的空間夠不夠。
1.4.3 strncmp
strncmp用于比較兩個字符串,但它最多比較len個字節(jié)。如果兩個字符串在第len個字符之前存在不等的字符,這個函數(shù)停止比較,返回結(jié)果。如果兩個字符串的前l(fā)en個字符相等,函數(shù)就返回零。
1.5 字符串查找基礎(chǔ)
標(biāo)準(zhǔn)庫中存在許多函數(shù),它們用各種不同的方法查找字符串。
1.5.1 查找一個字符
在一個字符串中查找一個特定字符最容易的方法是使用strchr和strchr函數(shù),它們的原型如下:
char *strchr( char const *str, int ch);
char *strrchr( char const *str, int ch);
它們的第二個參數(shù)是一個整型值。但是,它包含了一個字符值(ASCII)。strchr在字符串中str查找字符ch第1次出現(xiàn)的位置,找到后函數(shù)返回一個指向該位置的指針。如果該字符并不存在于字符串中,函數(shù)就返回一個NUL指針。
strrchr的功能與strchr基本一致,只是它所返回的是一個指向字符串中該字符最后一次出現(xiàn)的位置(r:最右邊)。
例如:
char src[] = "abc12def12";
printf("the first = %s\n",strchr(src,49));//strchr(src,'1')
1.5.2 查找任何幾個字符
strprk是個更為常見的函數(shù),它是查找任何一組字符第一次在字符串中出現(xiàn)的位置,它的原型如下:
char *strpbrk( char const *str, char const *group);
這個函數(shù)返回一個指向str中第1個匹配group中任何一個字符的字符位置。如果未找到函數(shù)返回一個NULL指針。
例如:
char src[] = "123qaz!@#";
char group[] = "aq!";
printf("location = %s\n",strpbrk(src,group));//qaz!@#,group中的字符第1次出現(xiàn)的位置是q
1.5.3 查找一個子串
為了在字符串中查找一個子串,我們可以使用strstr函數(shù),它的原型如下:
char *strstr( char const *s1, char const *s2 );
這個函數(shù)在s1中查找整個s2第1次出現(xiàn)的位置,并返回一個指向該位置的指針。如果s2沒有完整的出現(xiàn)在s1中任何地方,函數(shù)返回NULL指針。如果s2是一個空字符串,函數(shù)就返回s2。
1.6 高級字符串查找
1.6.1 查找一個字符串前綴
strspn和strcspn函數(shù)用于在字符串的起始位置對字符計數(shù)。它們的函數(shù)原型如下:
size_t strspn( char const *str, char const *group );
size_t strcspn( char const *str, char const *group );
1.6.2 查找標(biāo)記
一個字符串常常包含幾個單獨的部分,它們彼此分隔開來。每次為了處理這些部分,你首先必須把它們從字符串中抽取出來。這個任務(wù)正是strtok函數(shù)所實現(xiàn)的功能。它從字符串中隔離各個單獨的稱為標(biāo)記(token)的部分,并丟棄分割符。它的原型如下:
char *strtok( char *str, char const *sep);
sep參數(shù)是個字符串,定義了用作分隔符的字符集。str指定一個字符串,它包含零個或多個有sep字符串中一個或多個分隔符分隔的標(biāo)記。strtok找到str的下一個標(biāo)記,并將其用NUL結(jié)尾,然后返回一個指向這個標(biāo)記的指針。
高級字符串查找將另外詳解描述!
1.7 字符操作
標(biāo)準(zhǔn)庫包含了兩組函數(shù),用于操作單獨的字符,它們的原型位于頭文件ctype.h。第一組函數(shù)用于字符分類,第二組函數(shù)用于轉(zhuǎn)換字符。
1.7.1 字符分類
每個分類函數(shù)接受一個包含字符值的整型參數(shù)。函數(shù)測試這個字符并返回一個整型值,表示真或假。
int isalnum( int ch );
int iscntrl( int ch );
int islower( int ch );
int isprint( int ch );
int isupper( int ch );
int isspace( int ch );
1.7.2 字符轉(zhuǎn)換
轉(zhuǎn)換函數(shù)把大寫字母轉(zhuǎn)換為小寫字母或把小寫字母轉(zhuǎn)換為大寫字母。它們的函數(shù)原型如下:
int tolower( int ch );
int toupper( int ch );
toupper函數(shù)返回其參數(shù)的對應(yīng)大寫形式,tolower函數(shù)返回其參數(shù)的對應(yīng)的小寫形式。如果函數(shù)參數(shù)并不是處于一個適當(dāng)?shù)拇笮懙淖址?,函?shù)將不修改直接返回。
提示:
直接測試或操縱字符將會降低程序的可移植性。例如,考慮下面這條語句,它試圖測試ch是否是一個大寫字符。
if( ch = 'A' ch = 'z' )
這條語句在使用ASCII字符集的機(jī)器上能夠運(yùn)行,但是在使用EBCDIC字符集的機(jī)器上將會失敗。另一方面,下面這條語句
if ( isupper( ch ) )
無論機(jī)器使用哪個字符集,它都能順利進(jìn)行,因此字符分類和轉(zhuǎn)換函數(shù)可以提高函數(shù)的可移植性。
1.8 內(nèi)存操作
在非字符串?dāng)?shù)據(jù)中包含零值的情況并不罕見,此時無法使用字符串處理函數(shù)來處理這種類型的數(shù)據(jù),因為當(dāng)它們遇到第1個NUL字節(jié)時就停止工作。我們應(yīng)該使用另外一組相關(guān)的函數(shù),它們的操作與字符串函數(shù)類似,但這些函數(shù)能夠處理任意的字符序列。下面是它們的原型:
void *memcpy( void *dst, void const *src, size_t length );
void *memmvoe( void *dst, void const *src, size_t length );
void *memcmp( void const *a, void const *b, size_t length);
void *memchr( void const *a, int ch, size_t length);
void *memset( void *a, int ch, size_t length);
每個原型都包含一個顯示的參數(shù)說明需要處理的字節(jié)數(shù),它們在遇到NUL字節(jié)時并不會停止工作。
1.8.1 memcpy
void *memcpy( void *dst, void const *src, size_t length );
memcpy從src的起始位置復(fù)制length個字節(jié)到dst的內(nèi)存起始位置,我們可以使用這種方法復(fù)制任何類型的值。第3個參數(shù)length指定了復(fù)制值的長度(以字節(jié)計)。如果src和dst以任何形式出現(xiàn)重疊,其結(jié)果都是未定義的。
例如:
char temp[SIZE],value[SIZE];
...
memcpy( temp, value, SIZE);//從數(shù)組value復(fù)制SIZE個字節(jié)到temp
如果兩個數(shù)組為整型數(shù)組該怎么辦?下面語句完成可以完成這項任務(wù):
memcpy( temp, value, sizeof(value) );
memcpy()前兩個參數(shù)類型是void*型指針,而任何類型的指針都可以轉(zhuǎn)化為void*型指針。
1.8.2 memmove
void *memmvoe( void *dst, void const *src, size_t length );
memmove函數(shù)的行為和memcpy差不多,只是它的源和目標(biāo)操作數(shù)可以重疊。它的內(nèi)部實現(xiàn)過程:把源操作數(shù)復(fù)制到一個臨時位置,這個臨時的位置不會與源或目標(biāo)操作數(shù)重疊,然后再把它從這個臨時位置復(fù)制到目標(biāo)操作數(shù)。如果源和目標(biāo)參數(shù)真的可能存在重疊,就應(yīng)該使用memmove,如下所示:
//Shift the values int the x array left one position.
memmove( x, x+1, ( count-1 ) * sizeof(x[0]) );
1.8.3 memcmp
void *memcmp( void const *a, void const *b, size_t length);
memcmp對兩段內(nèi)存的內(nèi)容進(jìn)行比較,這兩段內(nèi)存分別起始于a和b,共比較length個字節(jié)。這些值按照無符號字符逐字進(jìn)行比較,函數(shù)的返回值與strcmp函數(shù)一樣。由于這些值是根據(jù)一串無符號字節(jié)進(jìn)行比較的,所以memcmp函數(shù)用于比較不是單字節(jié)的數(shù)據(jù)如整數(shù)或浮點數(shù)時可能出現(xiàn)不可預(yù)料的結(jié)果。
1.8.4 memchr
void *memchr( void const *a, int ch, size_t length);
memchr從a的起始位置開始查找字符ch第一次出現(xiàn)的位置,并返回一個指向該位置的指針,它共查找length個字節(jié)。如果在length個字節(jié)中未找到該字符,函數(shù)就返回NULL指針。
1.8.5 memset
void *memset( void *a, int ch, size_t length);
memset函數(shù)把從a開始的length字節(jié)都設(shè)置為字符值ch。例如:
memset( buffer, 0, SIZE);//把buffer前SIZE個字節(jié)都初始化為‘\0’
文章知識點與官方知識檔案匹配
C技能樹字符串字符串輸入與輸出
106612 人正在系統(tǒng)學(xué)習(xí)中
打開CSDN,閱讀體驗更佳
字符串、字符和字節(jié)
三者關(guān)系: 字符串是由一個個字符組成的,每個字符又由一個或多個字節(jié)來表示,每個字節(jié)又由8個bit位來表示。 字符:計算機(jī)中使用的文字和符號,比如1、2、A、B、%等等。 字節(jié)(Byte):一種計量單位,表示數(shù)據(jù)量多少,它是計算機(jī)信息技術(shù)用于計量存儲容量的一種計量單位。 不同編碼里,字符和字節(jié)的對應(yīng)關(guān)系不同: ①ASCII碼中,一個英文字母占一個字節(jié)的空間,一個中文漢字占兩個字節(jié)的空間。 ②UTF-8編碼中,一個英文字符等于一個字節(jié),一個中文等于三個字節(jié)。 ③Unicode編碼中,一個英文等于兩個字節(jié),一個中
繼續(xù)訪問
字符與字符串(新手,c語言)
字符與字符串,新手詳細(xì)筆記,c語言
繼續(xù)訪問
?
最新發(fā)布 字符串(字節(jié))長度計算
一般英文占一個長度,漢字占兩個長度(字節(jié)),獲取中英混合的字符串長度。
繼續(xù)訪問
熱門推薦 字節(jié),字符及占用內(nèi)存大小情況
(一)“字節(jié)”的定義 字節(jié)(Byte)是一種計量單位,表示數(shù)據(jù)量多少,它是計算機(jī)信息技術(shù)用于計量存儲容量的一種計量單位。 (二)“字符”的定義 字符是指計算機(jī)中使用的文字和符號,比如1、2、3、A、B、C、~!·#¥%……—*()——+、等等。 (三)“字節(jié)”與“字符” 它們完全不是一個位面的概念,所以兩者之間沒有“區(qū)別”這個說法。不同編碼里,字符和字節(jié)的對應(yīng)關(guān)系不同:
繼續(xù)訪問
c語言字符串長度,占用字節(jié)大小,存放位置等問題
參考文章: 1、三者長度strlen問題 int main () { char *str="xiaolong"; printf("%d\n",strlen(str)); return 0; } 結(jié)果: #include stdio.h #include string.h int main ...
繼續(xù)訪問
Linux 中與字符串相關(guān)的函數(shù)strpbrk、strcasecmp、strspn(不間斷更新)
本篇博客旨在整理出所有Linux網(wǎng)絡(luò)編程中常用的字符串相關(guān)的函數(shù),這些函數(shù)普遍用在處理網(wǎng)絡(luò)通信中的字符串?dāng)?shù)據(jù)。話不多說,直接進(jìn)入正題。 1、strpbrk函數(shù) #includestring.h char* strpbrk(char* s1, char* s2); strpbrk()從第一個字符指針指向的位置 向后檢查每個字符,直到遇到\0(不檢查\0),如果檢查到的某個字符在s2指向的字符串中,那么返回他的地址,并停止檢查。 如果s1 、s2沒有相同字符,返回NULL。 注:傳入strpb
繼續(xù)訪問
Linux下對字符串處理的實現(xiàn)函數(shù)(一)
1.Linux下字符串大小寫轉(zhuǎn)換 2.Linux下刪除字符串中對應(yīng)標(biāo)志字符串的首字符串 3.Linux下刪除字符串中不需要的空格(示例:逗號前后) 5.Linux下處理字符串——忽略雙引號內(nèi)容 6.Linux下字符串分割——忽略雙引號內(nèi)容.........
繼續(xù)訪問
?
linux 純字符串,Linux下常用的字符串函數(shù)
13. strlen()(返回字符串長度)相關(guān)函數(shù)表頭文件 #include定義函數(shù) size_t strlen (const char *s);函數(shù)說明 strlen()用來計算指定的字符串s的長度,不包括結(jié)束字符"\0"。返回值 返回字符串s的字符數(shù)。范例#includemain(){char *str = "12345678";printf("str length = %d\n"...
繼續(xù)訪問
linux 字符串操作函數(shù)
1 strchr 函數(shù)原型:extern char *strchr(char *str,char character) 參數(shù)說明:str為一個字符串的指針,character為一個待查找字符。 所在庫名:#include string.h 函數(shù)功能:從字符串str中尋找字符character第一次出現(xiàn)的位置。 返回說明:返回指向第一次出現(xiàn)字符cha...
繼續(xù)訪問
linux下字符串操作,Linux shell 字符串操作詳解-Fun言
1、Linux shell 截取字符變量的前8位實現(xiàn)方法有如下幾種:expr substr “$a” 1 8echo $a|awk ‘{print substr(,1,8)}’echo $a|cut -c1-8echo $expr $a : ‘\(.\\).*’echo $a|dd bs=1 count=8 2/dev/null2、按指定的字符串截取(1)第一種方法:從左向右截取最后一個s...
繼續(xù)訪問
Linux操作字符串
目錄 獲取字符串長度: 提取子字符串: 子字符串消除 字符串替換 子字符串所在位置 獲取字符串長度: 從字符串開始的地方匹配子字符串的長度: 1.expr match "$string" '$substring' 2.expr "$string" : '$substring 注釋:$substring是一個正則表達(dá)式 提取子字符串: 1.${string:position} 在string 中從位置$position 開始提取子字符串. 如果$string為"*"或"@",
繼續(xù)訪問
Linux字符串操作
Linux字符串操作 描述 shell內(nèi)置一系列的操作符合,可以對字符串進(jìn)行操作; 常用操作 表達(dá)式 含義 ${#string} $string的長度 ${string:position} 在string中從位置position開始提取子串 ${string:position:length} 在string中從位置position開始提取長度為$length的子串 ${string#substring} 從變量string的開頭刪除最短匹配substring的子串 ${s
繼續(xù)訪問
linux 字符串比較、數(shù)值比較
字符串相等: [[ $str1 == $str2 ]] 字符串不相等: [[ $str1 != $str2 ]] 字符串大小比較: [[ $str1 $str2 ]] 字符串等于空: [[ -z $str2 ]] 字符串不等于空: [[ -n $str2 ]] 二元比較操作符,比較變量或者比較數(shù)字.注意數(shù)字與字符串的區(qū)別. 整數(shù)比較 -eq 等于,如:if [ "$a" -eq "$b" ] -ne
繼續(xù)訪問
Linux下常用的字符串函數(shù)合集分享
轉(zhuǎn)自:Linux下常用的字符串函數(shù)一、字符間的轉(zhuǎn)換1 tolower(將大寫字母轉(zhuǎn)換成小寫字母)相關(guān)函數(shù)isalpha,toupper表頭文件 include定義函數(shù)int tolower(int c);函數(shù)說明。。。 ...
繼續(xù)訪問
字符串(Linux應(yīng)用編程篇)
關(guān)于字符串的相關(guān)操作有 輸入、輸出、合并、修改、比較、轉(zhuǎn)換、復(fù)制、搜索等等 一、字符串I/O 宏定義文件指針:標(biāo)準(zhǔn)輸入設(shè)備stdin、標(biāo)準(zhǔn)輸出設(shè)備stdout、標(biāo)準(zhǔn)錯誤設(shè)備stderr 字符串輸出 putchar()、puts()、fputc()、fputs()這些函數(shù)也是標(biāo)準(zhǔn) I/O 函數(shù),標(biāo)準(zhǔn)C庫函數(shù),且應(yīng)層的函數(shù)是有緩沖的,性能和效率要比系統(tǒng)調(diào)用要高。 /* @ puts函數(shù) @ 頭文件:#include stdio.h @ s:需要進(jìn)行輸出的字符串 @ 返回值:成功返回一
繼續(xù)訪問
Linux下的基本C編程的三類高頻函數(shù)操作第二類——字符串操作函數(shù)(str)
一,strlen和sizeof strlen一般用來求字符串長度,而sizeof是求這一段儲存空間的大小。它們的區(qū)別在于strlen不計算空白符的大小,且遇到\0就會停止工作。 例如 #include stdio.h #include string.h int main(int argc, char **argv) { printf("%ld\n",strlen("hello baby"));//結(jié)果為10; printf("%ld
繼續(xù)訪問
?
linux shell 函數(shù)返回字符串,如何從Bash函數(shù)返回字符串值
您可以讓函數(shù)將變量作為第一個arg,然后使用要返回的字符串修改變量。#!/bin/bashset -xfunction pass_back_a_string() {eval "$1='foo bar rab oof'"}return_var=''pass_back_a_string return_varecho $return_var打印“ foo bar rab oof”。編輯:在適當(dāng)?shù)奈恢锰砑?..
繼續(xù)訪問
字符串長度與字節(jié)個數(shù)
在純ASCII碼下,字節(jié)數(shù)=字符串長度=字符個數(shù),因為每個字符就一個字節(jié)。 在Unicode下,字節(jié)數(shù)/2=字符串長度=字符個數(shù),因為每個字符都是2個字節(jié)。 在ASCII碼與其它雙字節(jié)字符系統(tǒng)混用時,字節(jié)數(shù)=ASCII碼字符個數(shù)+雙字節(jié)字符個數(shù)*2,而此時字符串長度到底怎么統(tǒng)計就不好說了,有的語言如C語言,此時字符串長度=字節(jié)數(shù),有的語言如JS,此時字符產(chǎn)長度=字符個數(shù)。
繼續(xù)訪問
Linux 常用C函數(shù)(內(nèi)存及字符串操作篇2)
Linux 常用C函數(shù)(內(nèi)存及字符串操作篇2)2007-03-22 11:36 strcat(連接兩字符串)
繼續(xù)訪問
c
c++
字符串處理
?寫評論
?
評論
?
1
【牢記24條】
1.不要看到別人的回復(fù)第一句話就說:給個代碼吧!你應(yīng)該想想為什么。當(dāng)你自己想出來再參考別人的提示,你就知道自己和別人思路的差異。
2.初學(xué)者請不要看太多太多的書那會誤人子弟的,先找本系統(tǒng)的學(xué),很多人用了很久都是只對部分功能熟悉而已,不系統(tǒng)還是不夠的。
3.看幫助,不要因為很難而自己是初學(xué)者所以就不看;幫助永遠(yuǎn)是最好的參考手冊,雖然幫助的文字有時候很難看懂,總覺得不夠直觀。
4.不要被對象、屬性、方法等詞匯所迷惑;最根本的是先了解最基礎(chǔ)知識。
5.不要放過任何一個看上去很簡單的小問題--他們往往并不那么簡單,或者可以引伸出很多知識點;不會舉一反三你就永遠(yuǎn)學(xué)不會。
6.知道一點東西,并不能說明你會寫c++,是需要經(jīng)驗積累的。
7.學(xué)c++并不難,--難的是長期堅持實踐和不遺余力的博覽群書;
8.看再多的書是學(xué)不全c++,要多實踐。
9.把時髦的技術(shù)掛在嘴邊,還不如把過時的技術(shù)記在心里;
10.學(xué)習(xí)c++最好的方法之一就是多練習(xí);
11.在任何時刻都不要認(rèn)為自己手中的書已經(jīng)足夠了;
12.看得懂的書,請仔細(xì)看;看不懂的書,請硬著頭皮看;
13.別指望看第一遍書就能記住和掌握什么——請看第二遍、第三遍;
14.請把書上的例子親手到電腦上實踐,即使配套光盤中有源文件;
15.把在書中看到的有意義的例子擴(kuò)充;并將其切實的運(yùn)用到自己的工作中;
16.不要漏掉書中任何一個練習(xí)——請全部做完并記錄下思路;
17.當(dāng)你用腳本到一半?yún)s發(fā)現(xiàn)自己用的方法很拙劣時,請不要馬上停手;請盡快將余下的部分粗略的完成以保證這個代碼的完整性,然后分析自己的錯誤并重新編寫和工作。
18.別心急,寫腳本確實不容易;水平是在不斷的實踐中完善和發(fā)展的;
19.每學(xué)到一個腳本難點的時候,嘗試著對別人講解這個知識點并讓他理解----你能講清楚才說明你真的理解了;
20.記錄下在和別人交流時發(fā)現(xiàn)的自己忽視或不理解的知識點;
21.保存好你做過的所有的源文件----那是你最好的積累之一;
22.對于網(wǎng)絡(luò),還是希望大家能多利用一下,很多問題不是非要到論壇來問的,首先你要學(xué)會自己找答案,比如google、百度都是很好的搜索引擎,你只要輸入關(guān)鍵字就能找到很多相關(guān)資料,別老是等待別人給你希望,看的出你平時一定也很懶!
23,到一個論壇,你學(xué)會去看以前的帖子,不要什么都不看就發(fā)帖子問,也許你的問題早就有人問過了,你再問,別人已經(jīng)不想再重復(fù)了,做為初學(xué)者,誰也不希望自己的帖子沒人回的。
24,雖然不是打擊初學(xué)者,但是這句話還是要說:論壇論壇,就是大家討論的地方,如果你總期望有高手總無償指點你,除非他是你親戚??!討論者,起碼是水平相當(dāng)?shù)牟庞杏懻摰恼f法,如果水平真差距太遠(yuǎn)了,連基本操作都需要別人給解答,誰還跟你討論呢。能找到很多相關(guān)資料,別老是等待別人給你希望,看的出你平時一定也很懶!
浮躁的人容易問:我到底該學(xué)什么;----別問,學(xué)就對了;
浮躁的人容易問:c++有錢途嗎;----建議你去搶銀行;
浮躁的人容易說:我要中文版!我英文不行!----不行?學(xué)呀!
浮躁的人分兩種:只觀望而不學(xué)的人;只學(xué)而不堅持的人;
浮躁的人永遠(yuǎn)不是一個高手。
十部算法經(jīng)典著作 合集
二級試題全集
高質(zhì)量C++/C編程指南
應(yīng)用C++技術(shù)構(gòu)建優(yōu)質(zhì)軟件
ASCII碼表
C\C++語言程序百例
;C++YuanYanChenXuBaili
C++編碼規(guī)范與指導(dǎo)
C++PrimerPlus4th
C++語言程序設(shè)計課件(作者:鄭莉)
C++語言程序設(shè)計
C語言函數(shù)示例集
C高級編程技術(shù)
C語言技術(shù)文章
C++疑難解答
C++實踐之路
C++應(yīng)用程序例解
C++參考
CPrimerPlus5thEdition習(xí)題答案
C語言編程寶典之一
C語言參考手冊
C語言學(xué)習(xí)和精華文摘
數(shù)據(jù)訪問模式
數(shù)據(jù)結(jié)構(gòu)與算法綜合資料庫
數(shù)據(jù)結(jié)構(gòu)-嚴(yán)蔚敏
Effective C++
GenericProgramming
設(shè)計模式迷你手冊
經(jīng)典排序算法
譚浩強(qiáng)C語言
TheC++ProgrammingLanguage3rdEd
TheCprogrammingLanguage
TurboC2.0集成開發(fā)環(huán)境的使用
用VC開發(fā)ACTIVEX
;MFC/ActiveXProgramingWithVC
用DirctX9進(jìn)行高級3D游戲程序設(shè)計
;MFC/Advanced3DGameProgrammingwithDirectX9
APracticalGuideUsingVisual C++andATL
;MFC/APracticalGuideUsingVisualCandATL
21天學(xué)會VC數(shù)據(jù)庫編程
;MFC/DatabaseProgrammingWithVisualC6In21Days
STL輕松入門
;MFC/EasySTL
InsideAtl
;MFC/InsideAtl
COM+組件服務(wù)技術(shù)內(nèi)幕
;MFC/InsideCOM+
MFC參考手冊
;MFC/MFCReference
Windows網(wǎng)絡(luò)編程技術(shù)
;MFC/NetworkProgramingForMicrosoftWindows
OGRE手冊
;MFC/OGREManual
OpenGL基礎(chǔ)圖形編程
;MFC/OpenGLJiChuTuXingBianCheng
MFC程序設(shè)計
;MFC/progmfc2
VC技術(shù)內(nèi)幕
;MFC/ProgramingVC
Windows核心編程
;MFC/ProgrammingApplicationsforMicrosoftWindows
21天學(xué)會ActiveX編程
;MFC/TeachYourselfActivexIn21Days
游戲編程大師技巧(第二版)
;MFC/TricksofWinGameProgrammingGurus2ed
VC編程經(jīng)驗總結(jié)
;MFC/VCBianChengJianYanZongJie
VC編程資料
;MFC/VCBianChengZiliao
VC常見問題集(中文)
;MFC/VCFaqsCN
VC高級編程
;MFC/VCGaoJiBianCheng
vchome圖形圖像編程技術(shù)篇
;MFC/vchomeGraph
VC知識庫
;MFC/vckbase
VC語言參考手冊
;MFC/VCLANG
vc++ 編程指南
;MFC/VCProgramGuide
Windows程序設(shè)計
;MFC/WindowsProgramming
Winsock程序員疑難解答
;MFC/WinsockProgrammerFAQ
Microsoft編程精粹
;MFC/WritingCleanCode
C語言中 各個模塊 其實就是函數(shù)的合集
所以 要合起來 只要把這些模塊 寫入到一個文件就好了啊 然后用一個main整合
也可以建立多個文件,加入到project中,一起編譯。