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

            伊人久久免费视频| 久久久久久人妻无码| 日韩va亚洲va欧美va久久| 武侠古典久久婷婷狼人伊人| 人妻精品久久无码区| 精品人妻伦九区久久AAA片69| 亚洲伊人久久精品影院| 91精品国产91热久久久久福利| 久久久久久久波多野结衣高潮| 国产精品久久久久乳精品爆| 久久久久亚洲AV无码观看 | 久久久综合香蕉尹人综合网| 精品伊人久久大线蕉色首页| 久久国产高清一区二区三区| 久久精品人人槡人妻人人玩AV| 久久人人超碰精品CAOPOREN | 久久这里有精品视频| www.久久热.com| 久久久久人妻一区精品性色av| 2020久久精品亚洲热综合一本| 久久涩综合| 中文字幕久久精品| 久久影院亚洲一区| 久久亚洲AV永久无码精品| 免费国产99久久久香蕉| 国产日产久久高清欧美一区| 亚洲va中文字幕无码久久不卡| 亚洲精品乱码久久久久久蜜桃| 免费一级做a爰片久久毛片潮| 国产综合精品久久亚洲| 久久精品国产一区二区| 精品无码久久久久久久久久| 国内精品久久久久久久涩爱| 久久久WWW免费人成精品| 欧美一级久久久久久久大| 久久精品中文字幕第23页| 久久青青国产| 中文字幕无码免费久久| 2021久久精品国产99国产精品| 久久国产精品久久久| 精品无码久久久久久久久久 |