如何更好的進(jìn)行C++代碼編譯
在剛剛剛開(kāi)始學(xué)C++代碼時(shí)遇到一個(gè)問(wèn)題,這個(gè)問(wèn)題導(dǎo)致程序不能夠完全的進(jìn)行運(yùn)行,看完本文后對(duì)您一定會(huì)大有幫助,下文除了學(xué)習(xí)C++代碼的基本性質(zhì)外還對(duì)C++代碼的編程進(jìn)行全面研究。如下代碼:
- #include
- int main()
- ...{
- char a,b;
- printf("Please input the first character:");
- scanf("%c", &a);
- printf("Please input the second character:");
- scanf("%c", &b);
- printf("The two characters are %c, %c", a, b);
- return 0;
- }
程序運(yùn)行結(jié)果如下:而下面這段程序卻可以正常運(yùn)行:
運(yùn)行結(jié)果如下:
- #include
- int main()
- ...{
- char a;
- int b;
- printf("Please input the first character:");
- scanf("%c", &a);
- printf("Please input the second integer:");
- scanf("%d", &b);
- printf("The two characters are %c, %d", a, b);
- return 0;
- }
當(dāng)時(shí)對(duì)這個(gè)問(wèn)題很困惑,時(shí)間一長(zhǎng)就慢慢淡忘了。昨天一個(gè)同學(xué)問(wèn)到一個(gè)C++運(yùn)算符重載的問(wèn)題,如下代碼,其中的while循環(huán)起什么作用,好像注釋掉后程序運(yùn)行沒(méi)什么差別:
- iostream& operator >> (iostream& is, b& s)
- ...{
- char temp[b::MAX] = ...{0};
- is.get();
- is.get(temp, b::MAX);
- if(strlen(temp)>0)
- ...{
- strncpy(b.str, temp, b::MAX);
- }
- while(is && is.get()!=' ')
- ...{
- continue;
- }
- return is;
- }
果然,當(dāng)輸入字符串小于b::MAX時(shí)一切正常,當(dāng)超過(guò)b::MAX時(shí),當(dāng)輸入完***個(gè)字符串回車后,沒(méi)等輸入第二個(gè)字符串,程序就把b1和b2的內(nèi)容都顯示出來(lái)了,而b2 的內(nèi)容正是輸入的字符串超過(guò)b::MAX長(zhǎng)度的部分,說(shuō)明前面的分析是正確的。
今天又想起這個(gè)問(wèn)題,突然聯(lián)想到以前C++語(yǔ)言的兩個(gè)scanf連用產(chǎn)生的問(wèn)題,靈機(jī)一動(dòng),難道也是輸入緩沖區(qū)沒(méi)有自動(dòng)清空產(chǎn)生的問(wèn)題?當(dāng)連續(xù)用scanf輸入兩個(gè)字符的時(shí)候,輸入***個(gè)字符后回車。
結(jié)果換行符被當(dāng)作第二個(gè)字符輸入了,scanf可不會(huì)區(qū)分什么換行符還是普通字符,而當(dāng)輸入一個(gè)字符,再輸入一個(gè)整數(shù)時(shí),因?yàn)轭愋筒黄ヅ涞脑?,scanf會(huì)將換行符忽略而等待輸入正確的整數(shù)后才返回,所以得到了正確的結(jié)果,哈哈,原來(lái)如此!!!
可見(jiàn),C++中的標(biāo)準(zhǔn)輸入流已經(jīng)對(duì)于換行符做了處理,看來(lái)在C++中利用標(biāo)準(zhǔn)輸入處理特殊字符要自己做一些工作了
【編輯推薦】