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

            力為的技術(shù)博客

            聯(lián)系 聚合 管理
              154 Posts :: 1 Stories :: 561 Comments :: 0 Trackbacks

            ?取得std::ostringstream里的內(nèi)容可以通過str()和str(string&)成員函數(shù)。由于str()返回的是臨時(shí)對(duì)象,因而會(huì)有如下誤用:

            const ? char * ?pBuffer? = ?oss.str().c_str();

            pBuffer指向的內(nèi)存已被析夠!

            測(cè)試代碼:

            ????????ostringstream?oss;
            ????????oss?
            << ? " something?you?like " ? << ?endl;

            // ?can't?work!
            ???????? const ? char * ?szData1? = ?oss.str().c_str();
            ????????
            // work!
            ???????? string & ?ss? = ?oss.str();
            ????????
            const ? char * ?szData2? = ?ss.c_str();


            例子:
            用std::ostringstream獲取整個(gè)文件的內(nèi)容:

            ????????ifstream?ifs( " in.txt " );

            ????????istream_iterator
            < char > ?inpos(ifs);
            ????????istream_iterator
            < char > ?endpos;
            ????????ostream_iterator
            < char > ? out (oss);
            ????????std::copy(inpos,?endpos,?
            out );

            // 有些情況下需要取得buffer:
            ???????? string & ?ss? = ?oss.str();
            ????????
            const ? char * ?szData? = ?ss.c_str();


            ?

            posted on 2006-06-08 16:49 力為 閱讀(6487) 評(píng)論(5)  編輯 收藏 引用 所屬分類: 4. C++ FAQ

            評(píng)論

            # re: std::ostringstream::str()返回臨時(shí)對(duì)象 2006-06-08 17:26 LOGOS
            const char * szData1 = oss.str().c_str();
            szData1[0] == '\0';
            不過既然是臨時(shí)變量,你這么用
            string & ss = oss.str();
            const char * szData2 = ss.c_str();
            不符合規(guī)范吧  回復(fù)  更多評(píng)論
              

            # re: std::ostringstream::str()返回臨時(shí)對(duì)象 2006-06-08 17:30 wzq
            To LOGOS:
            but it really works!  回復(fù)  更多評(píng)論
              

            # re: std::ostringstream::str()返回臨時(shí)對(duì)象 2006-06-08 17:48 力為
            to LOGOS:
            這種情況下編譯器一般會(huì)做擴(kuò)展:
            為臨時(shí)變量設(shè)置引用,那么臨時(shí)變量的生命周期將和引用的生命周期一致  回復(fù)  更多評(píng)論
              

            # re: std::ostringstream::str()返回臨時(shí)對(duì)象 2006-06-12 21:41 ooo
            // 有些情況下需要取得buffer:
            string & ss = oss.str();
            const char * szData = ss.c_str();

            這是是不是該該成:
            const string & ss = oss.str();
            const char * szData = ss.c_str();

            為臨時(shí)變量設(shè)置引用,那么臨時(shí)變量的生命周期將和引用的生命周期一致 ,
            就應(yīng)該加上 const, 可是在VC6.0上對(duì)這個(gè)語(yǔ)句string & ss = oss.str();且沒有錯(cuò)誤的提示.
              回復(fù)  更多評(píng)論
              

            # re: std::ostringstream::str()返回臨時(shí)對(duì)象 2006-12-13 10:26 jlupaopao
            @ooo
            g++下確實(shí)會(huì)有錯(cuò)誤報(bào)告
            error: invalid initialization of non-const reference of type 'std::string&' from a temporary of type 'std::basic_string<char, std::char_traits<char>, std::allocator<char> >'

            加上const就好了,其實(shí)加上const等同于
            string temp =oss.str();
            const string & ss = temp
            const char * szData = ss.c_str();
            既然如此為什么不直接寫string ss =oss.str(); 呢
              回復(fù)  更多評(píng)論
              

            亚洲精品乱码久久久久久蜜桃图片| 亚洲精品成人久久久| 亚洲中文字幕无码一久久区| 亚洲欧洲久久久精品| 1000部精品久久久久久久久| 国产精品无码久久久久| 精品国产乱码久久久久软件| 国产精品久久成人影院| 偷偷做久久久久网站| 久久国产高清字幕中文| 亚洲综合熟女久久久30p| 久久伊人精品青青草原日本| 久久中文骚妇内射| 精品国产乱码久久久久软件| 香蕉久久一区二区不卡无毒影院| 思思久久好好热精品国产| 99精品久久久久久久婷婷| 97久久超碰成人精品网站| 精品无码久久久久国产动漫3d| 热综合一本伊人久久精品| 国产激情久久久久影院| 久久成人精品视频| 国产精品一久久香蕉国产线看观看| 热久久最新网站获取| 久久这里都是精品| 久久免费观看视频| 久久国产影院| 亚洲国产成人乱码精品女人久久久不卡 | 色妞色综合久久夜夜| 三级片免费观看久久| 国产伊人久久| 久久亚洲2019中文字幕| 久久久久亚洲?V成人无码| 91精品国产91久久久久久蜜臀| 麻豆精品久久久一区二区| 亚洲国产精久久久久久久| 91精品国产高清久久久久久91 | 久久综合狠狠综合久久激情 | 久久久精品午夜免费不卡| 精品人妻伦一二三区久久| 亚洲精品成人久久久|