• <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>

            C++ Forever

            my feeling and C++'s
            posts - 5, comments - 12, trackbacks - 0, articles - 0

            C語言中strtok與strpbrk的區別(轉)

            Posted on 2008-06-26 22:16 HYin 閱讀(5523) 評論(4)  編輯 收藏 引用
            一、strpbrk:

            調用格式:result = strpbrk(source-string, searching-string)
            用途:在源字符串(source-string)中找出最先含有搜索字符串(searching-string)中的任一字符的位置并返回,若找不到則返回空指針。
            注意:返回值是指向源字符串的指針,所以在使用返回結果的時候,請確保源字符串的有效性。
            舉MSDN中的例子:
            數據:
            char string[100] = "The 3 men and 2 boys ate 5 pigs\n";
            char *result;
            調用:
            result = strpbrk( string, "0123456789" );//在string中找出最先出現0~9中某一個字符的位置
            printf( "1: %s\n", result++ );
            result = strpbrk( result, "0123456789" );
            printf( "2: %s\n", result++ );
            result = strpbrk( result, "0123456789" );
            printf( "3: %s\n", result );
            輸出的結果是:
            1. 3 men and 2 boys ate 5 pigs//最先發現3

            2: 2 boys ate 5 pigs//最先發現2,注意這時開始源串是上一次的結果的下一位置,即跳過了數字'3',下同

            3: 5 pigs//最先發現5

            =========================
            二、strtok:

            用法:token = strtok(source-str,seperator-str)
            用途:在source-str中找出以seperator-str中的字符為分隔的字符串,即是源串中除去了含有分隔串中的所有字符后余下的一段段的字符串,每調用一次找到一串,找不到則返回空串。
            注意:返回值是指向源串的指針,所以同樣要保證源串的有效性,此外,每次調用返回找到的子串的時候都會把源串中該子串的尾部字符(原來是搜索串中的某一字符)修改成'\0'字符。還有一個要注意的是,這個函數使用全局的靜態緩沖區(函數自己的靜態buffer),所以在某一個線程里不要同時調用這個函數來處理兩個字符串,否則極易出現不正常的結果,正確的處理方法是先找出一個字符串中的所有子串,然后才轉到處理另一個字符串。多線程之間則不會出現這種干擾。
            同樣舉MSDN中的例子:
            數據準備:
            char string[] = "A string\tof ,,tokens\nand some more tokens";
            char seps[] = " ,\t\n";
            char *token;
            調用示例:
            token = strtok( string, seps );
            while( token != NULL )
            {
            /* While there are tokens in "string" */
            printf( " %s\n", token );
            /* Get next token: */
            token = strtok( NULL, seps );
            /*注意到上面這個NULL,它表明的是從上次調用結果中strtok自有的緩沖區中繼續取出余下的子串*/
            }
            顯示結果:
            A //此時string[1]='\0',原先為空格
            string
            of
            tokens
            and
            some
            more
            tokens

            Feedback

            # re: C語言中strtok與strpbrk的區別(轉)  回復  更多評論   

            2008-06-27 09:33 by true
            可否談談為什么 多線程之間則不會出現這種干擾

            # re: C語言中strtok與strpbrk的區別(轉)  回復  更多評論   

            2008-06-27 10:58 by Jeff Chen
            @true

            我覺得strtok使用的緩沖區應該是TLS的。每個線程的TLS都是獨立的,相互隔離的。這樣的話,在多個線程中調用strtok函數才不會相互影響,出現類似在同一個線程中同時調用strtok兩次或以上時,出現的不正常情況。

            # re: C語言中strtok與strpbrk的區別(轉)  回復  更多評論   

            2008-06-28 11:21 by HYin
            @true
            strtok 這個函數使用全局的靜態緩沖區(函數自己的靜態buffer),所以在某一個線程里不要同時調用這個函數來處理兩個字符串,否則極易出現不正常的結果,正確的處理方法是先找出一個字符串中的所有子串,然后才轉到處理另一個字符串。多線程之間則不會出現這種干擾。

            # re: C語言中strtok與strpbrk的區別(轉)  回復  更多評論   

            2008-07-01 13:01 by 企業即時通訊
            聽說,有些標準庫函數,不支持多線程的。
            不知這些是不是。
            国产精品久久久久影院色| 久久夜色精品国产亚洲av| 久久人人爽人人爽人人片AV不| 亚洲欧美伊人久久综合一区二区| 久久成人国产精品免费软件| 久久精品毛片免费观看| 国产精品久久久久一区二区三区| 日日狠狠久久偷偷色综合96蜜桃 | 久久精品国产免费观看| 无码国内精品久久人妻| 丁香五月综合久久激情| 久久夜色精品国产噜噜麻豆| 国产一区二区精品久久凹凸| 久久亚洲AV成人出白浆无码国产| 丰满少妇人妻久久久久久4| 色婷婷综合久久久久中文| 久久久青草青青国产亚洲免观| 久久丫精品国产亚洲av不卡 | 久久99精品国产一区二区三区| 国产精品免费久久久久久久久 | 中文精品久久久久国产网址| 国产香蕉久久精品综合网| 久久精品国产清高在天天线| 久久精品国产亚洲av麻豆色欲 | 久久精品亚洲乱码伦伦中文 | 久久精品中文字幕一区| 99久久99这里只有免费的精品| 亚洲精品WWW久久久久久| 国产成人精品久久亚洲| 国产亚洲欧美成人久久片| 欧美噜噜久久久XXX| 东方aⅴ免费观看久久av| 久久99这里只有精品国产| 欧洲国产伦久久久久久久 | 国产精品一久久香蕉国产线看观看 | 91久久香蕉国产熟女线看| 国产精品久久久久久吹潮| 久久天天躁狠狠躁夜夜躁2O2O | 久久久久成人精品无码| 热RE99久久精品国产66热| 天堂无码久久综合东京热|