• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Benjamin

            靜以修身,儉以養(yǎng)德,非澹薄無以明志,非寧靜無以致遠(yuǎn)。
            隨筆 - 398, 文章 - 0, 評(píng)論 - 196, 引用 - 0
            數(shù)據(jù)加載中……

            標(biāo)準(zhǔn)C---關(guān)于字符串操作

            字符串操作是常用的操作之一,下面是相關(guān)的函數(shù)介紹和相關(guān)注意的地方,
            一、
            strtok查找函數(shù),這個(gè)函數(shù)改變了源字符串,而且第一個(gè)參數(shù)必須是數(shù)組,不能是指針或字符串,如果是指針或字符串,則會(huì)報(bào)異常,直接返回NULL.如果不想改變?cè)醋址膬?nèi)容,建議用strstr來查找子串。
            其他常用的查找函數(shù)有
            strchrstrrchr,前者在字符在字符串第一次出現(xiàn)的位置,后者則是查詢的是字符在字符串中出現(xiàn)的最后一次的位置;兩個(gè)函數(shù)返回的都是地址,注意,這里返回的首地址的值就是這個(gè)字符。這兩個(gè)查找函數(shù)都不會(huì)改變?cè)醋址?/span>(數(shù)組的)內(nèi)容。

            二、Strlenmemset,如下面的代碼:
            char* temp = (char*)malloc(67 * sizeof(char));
            Int leng = strlen(temp);
            Memset(temp,0,strlen(temp));
            Leng = strlen(temp);
            兩次leng的值是不一樣的,第一次是正確的值,第二次是0strlen找的是’\0’,但是不包括’\0’;

            三、strcpy等雖然不安全可,但是要記住:strcpy_s等是微軟自己搞的一套,在liunx上是無法使用的。如果要部分拷貝,我們可以在
            strcpy的參數(shù)上直接對(duì)地址加減或在strncpy上對(duì)源字符串的地址更改或是對(duì)strncpy上的第三個(gè)參數(shù)加以修改來達(dá)到目的。
            strcpy等不安全主要表現(xiàn)在沒有會(huì)發(fā)生字符串截?cái)唷?nbsp;  字符串沒有正確的結(jié)束符,還有就是字符串的邊界問題。
            malloc和free一般情況下要配對(duì),但是如果是static變量,則可以不用free,不會(huì)發(fā)生內(nèi)存泄漏的情況。

            四、構(gòu)造字符串---sprintf,提取一個(gè)字符串的某個(gè)字段---scanf,這兩個(gè)是相反的過程。
            sprintf常用在拼接字符串,如:sprintf(buffer,"%s=%s","Three",3);buffer中的字符串就是"Three=3",有時(shí)它可以替代strcat函數(shù);

            sscanf和sprintf是兩個(gè)相反的過程,如果你知道字符串的格式完全可以用這個(gè)函數(shù)還替代strtok和strstr這兩個(gè)查找函數(shù);例如:char str[] = "watch is 34.3433 !!!";
            那么我們可以提取34.3433,sscanf(str,"%s %s %f",ch,&t_fTemp);這個(gè)t_fTemp的值就是34.3433.

            五、提取子串和字符在字符串的位置:strstr、strtok、strchr等,這些函數(shù)有個(gè)缺憾:如果我們要查找字串“222”是否在“22222 tok“中時(shí),這幾個(gè)函數(shù)都不起作用,要么自己寫,要么自己根據(jù)字串在父串中的指針的下個(gè)地址的內(nèi)容來確定.例如:
            char str[] = "2222 tok";
            char end_char = ' ';//這個(gè)可由自己根據(jù)業(yè)務(wù)定義
            if(*(strstr(str,"222")+1) != end_char)
            {
            ..................
            }
            六、strstr函數(shù)另一個(gè)缺點(diǎn):char str[] = "port 56 78" char *ch = strstr(str,"port");ch的值是str的首地址,而非我們要的結(jié)果,如果把空格改成/t/r等轉(zhuǎn)義字符
            結(jié)果依然如此,我們?cè)谑褂胹tr相關(guān)的函數(shù)時(shí)要主義類似的問題,這種結(jié)果在解析協(xié)議和讀文件時(shí)是致命,而且是難以察覺的錯(cuò)誤。

            posted on 2010-07-28 21:10 Benjamin 閱讀(762) 評(píng)論(6)  編輯 收藏 引用 所屬分類: C/C++

            評(píng)論

            # re: 標(biāo)準(zhǔn)C---關(guān)于字符串操作  回復(fù)  更多評(píng)論   

            但是如果是static變量,則可以不用free,不會(huì)發(fā)生內(nèi)存泄漏的情況。

            這個(gè)怎么理解??
            2010-07-29 09:13 | egmkang

            # re: 標(biāo)準(zhǔn)C---關(guān)于字符串操作  回復(fù)  更多評(píng)論   

            _s,_t的那一套函數(shù)都是CRT函數(shù),Unix-Like米有
            如果嫌strcpy不安全,可以使用strncpy,帶n的都有防止越界的功能.
            2010-07-29 09:14 | egmkang

            # re: 標(biāo)準(zhǔn)C---關(guān)于字符串操作  回復(fù)  更多評(píng)論   

            如果是靜態(tài)變量是malloc產(chǎn)生的,可以不用free,不會(huì)發(fā)生內(nèi)存泄漏的情況;
            所有str函數(shù)都有越界問題,都不是安全的;很多的編程規(guī)范也是禁止使用這些函數(shù),在一些惡意代碼就是通過這些函數(shù)的漏洞來注入的。
            2010-07-29 13:40 | Benjamin

            # re: 標(biāo)準(zhǔn)C---關(guān)于字符串操作  回復(fù)  更多評(píng)論   

            char* temp = (char*)malloc(67 * sizeof(char));
            Int leng = strlen(temp);
            Memset(temp,0,strlen(temp));
            Leng = strlen(temp);
            兩次leng的值是不一樣的,第一次是正確的值,第二次是0;strlen找的是’\0’,但是不包括’\0’;

            strlen遇‘\0’結(jié)束,所以,在未memset之前,分配的內(nèi)存塊都是隨機(jī)值,有可能是0,第一次有可能不是固定的值
            2010-07-29 16:55 | roy

            # re: 標(biāo)準(zhǔn)C---關(guān)于字符串操作  回復(fù)  更多評(píng)論   

            @roy

            好像我有點(diǎn)過時(shí)了
            剛才分別在Linux/Solaris/Tru64/HP-UX下測試這段代碼N次,每次輸出都是0

            #include <stdio.h>
            #include <stdlib.h>
            #include <string.h>

            int main() {
            char *tmp = (char *) malloc(1024 * sizeof(char));
            printf("%d\n", strlen(tmp));
            free(tmp);
            return 0;
            }

            2010-07-29 17:11 | roy

            # re: 標(biāo)準(zhǔn)C---關(guān)于字符串操作  回復(fù)  更多評(píng)論   

            @roy
            不錯(cuò),第一次返回的值不是它本身的長度,是從分配的首地址開始起一直到找到結(jié)束符的長度,可能是0也可能是不是0.如果正好下一個(gè)地址存放的就是結(jié)束符,那么長度就恰巧為0,所以你上面的strlen返回0也正常。
            2010-07-29 21:21 | Benjamin
            久久久久人妻一区精品色| 久久亚洲高清观看| 99久久国产精品免费一区二区| 狠狠精品久久久无码中文字幕| 午夜精品久久久久久影视riav| 亚洲女久久久噜噜噜熟女| 91精品观看91久久久久久| 伊人久久大香线蕉精品不卡| 久久久久成人精品无码中文字幕| 国产亚洲美女精品久久久| 久久夜色精品国产噜噜亚洲AV | 亚洲精品国精品久久99热一| 国产午夜精品理论片久久影视| 亚洲国产成人久久精品99 | 久久66热人妻偷产精品9| 国产精品99久久久久久www| 久久笫一福利免费导航| 久久精品一区二区影院| 国产精品岛国久久久久| 亚洲αv久久久噜噜噜噜噜| 手机看片久久高清国产日韩| 国内精品久久久久久久亚洲| 91久久精一区二区三区大全| 亚洲va久久久噜噜噜久久狠狠| 欧美成a人片免费看久久| 99久久精品免费看国产| 久久国产精品久久国产精品| 97久久久久人妻精品专区| 久久久婷婷五月亚洲97号色| 狠狠色丁香久久婷婷综合_中 | 超级碰久久免费公开视频| 久久精品国产亚洲欧美| 99国内精品久久久久久久| 99久久精品免费看国产一区二区三区| 蜜臀久久99精品久久久久久小说| 久久久国产精品| 99久久综合狠狠综合久久| 国产精品美女久久久网AV| 久久婷婷五月综合成人D啪| 久久国内免费视频| 亚洲中文字幕无码一久久区|