1、str和strl是變量,意思就是象 int a;中的“a” 的作用,本身既不是函數(shù)也不是關(guān)鍵字,沒有特別意義。而strlen是測試字符串長度的函數(shù)。
目前成都創(chuàng)新互聯(lián)已為千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、網(wǎng)站托管、企業(yè)網(wǎng)站設(shè)計(jì)、新干網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
2、變量strLen,strText分別表示一個(gè)字符串的長度和字符串。Len()是取字符串長度的函數(shù),將strText字符串的長度得到后賦值給變量strLen。
3、strlen是求字符串的長度,但不包括字符串的null結(jié)束符。strlen為C語言庫函數(shù),包含于string.h中,作用為計(jì)算一個(gè)字符串(字符數(shù)組)中元素的個(gè)數(shù),即從數(shù)組頭部計(jì)數(shù),直到遇到字符串結(jié)束符\0為止,計(jì)數(shù)結(jié)果不包括\0。
果斷切換成c++版本的cout發(fā)現(xiàn)可以正常輸出。于是上網(wǎng)找答案,居然驚訝的發(fā)現(xiàn)printf輸出字符串是針對char *的,換言之,printf只能輸出c語言中的內(nèi)置數(shù)據(jù),string不是c語言內(nèi)置數(shù)據(jù)。
你的最后一行 printf(%c\n,X);應(yīng)該是只有0~100時(shí)才可以輸出對應(yīng)的字符X。但是你把它放在if語句的后面,那么不論你輸入什么數(shù)值,都要輸出X,但是當(dāng)輸入數(shù)值小于0或者大于100時(shí),X是沒有被賦值的。
還有個(gè)問題是:mystrcat最后return s;但是這個(gè)s已經(jīng)不是指定字符串的開始了。換句話說,你成功的連接了字符串,但是你返回的是這字符串之后的地址空間。
c_str()返回的指針保證指向一個(gè)size() + 1長的空間,而且最后一個(gè)字符肯定 \0 而data返回的指針則保證指向一個(gè)size()長度的空間,有沒有null-terminate不保證,可能有,可能沒有,看庫的實(shí)現(xiàn)了。嗯。。
而c_str(),是std:string的一個(gè)方法,作用是std:string轉(zhuǎn)換為 const char*。所以pStringRule-m_sString.c_str()作用是將CCString轉(zhuǎn)換為 const char*,但是cocos2d0以后,m_sString方法已經(jīng)被移除了。
C語言字符串以\0結(jié)尾,如果不以該符號結(jié)尾則輸出%s時(shí)會(huì)出錯(cuò),程序一直往存放字符串的地址訪問。而你的程序中并沒有賦\0給那兩個(gè)數(shù)組,所以會(huì)出現(xiàn)亂碼。
這是C語言習(xí)慣,務(wù)必養(yǎng)成!\x0d\x0a\0是字符串結(jié)束符,每當(dāng)解釋器看到這\0才會(huì)認(rèn)為字符串終止,而你的程序明顯沒有字符串結(jié)束符,所以連同垃圾內(nèi)存一起讀出來了?!盃C燙?!钡染褪抢鴥?nèi)存。