• <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)德,非澹薄無以明志,非寧靜無以致遠。
            隨筆 - 397, 文章 - 0, 評論 - 196, 引用 - 0
            數(shù)據(jù)加載中……

            淺析sstream庫

            <sstream>庫定義了三種類:istringstream、ostringstream和stringstream,分別用來進行流的輸入、輸出和輸入輸出操作。另外,每個類都有一個對應的寬字符集版本。
            <sstream>使用string對象來代替字符數(shù)組。這樣可以避免緩沖區(qū)溢出的危險。而且,傳入?yún)?shù)和目標對象的類型被自動推導出來,即使使用了不正確的格式化符也沒有危險。
            istringstream和ostringstream主要用在內(nèi)核格式化中(用cout的ostream方法將格式化信息寫入string對象中或是讀取string對象中的格式化信息)例如:
            ostringstream outstr;
            double price= 281.00;
            char* ps = "for a copy of the ISO/EIC C++ standard!";
            outstr << fixed;
            outstr << "Pay only$" << price << ps << end;
            string msg = outstr.str();
            istreamstring允許用istream方法讀取istringsteam對象中的數(shù)據(jù),也可以用使用string對象對istreamsting對象初始化。簡而言之:istirngstream和ostringstream可以使用
            istream和ostream類的方法來管理存儲在字符串的字符數(shù)據(jù)。
            stringstream通常是用來做數(shù)據(jù)轉(zhuǎn)換的。相比c庫的轉(zhuǎn)換,它更加安全,自動和直接。
            例如:#include <string>
            #include <sstream>
            #include <iostream>

            int main()
            {
                std::stringstream stream;
                std::string result;
                int i = 1000;
                stream << i; //將int輸入流
                stream >> result; //從stream中抽取前面插入的int值
                std::cout << result << std::endl; // print the string "1000"
            }

            除了基本類型的轉(zhuǎn)換,也支持char *的轉(zhuǎn)換。

             

            #include <sstream>
            #include <iostream>

            int main()
            {
                std::stringstream stream;
                char result[8] ;
                stream << 8888; //向stream中插入8888
                stream >> result; //抽取stream中的值到result
                std::cout << result << std::endl; // 屏幕顯示 "8888"
            }

            需要注意的是,下面的寫法是不正確的:ifsream fs(Filename);
            stringsteam buff;
            buff << fs.rubf();//這句代碼可以一次性把文件寫入一個字符串中,然后將Outbuff.str()的值賦給一個string對象就可以。
            buff << fs;這樣寫是錯誤的,看看下面的<<運算符的定義就知道了,它不接受這樣的參數(shù)。
            但可以這樣寫fs>>buf;這樣寫才正確。
            cout << Outbuff << endl;
            這樣寫,編譯器可以通過編譯,但是運行后是空值。改成這樣的才行:cout << Outbuff.rubf()<< endl;
            istringstream和ostringstream在文件流的用法和stringstream的用法類似,必須用rubf方法才可以看到內(nèi)容。
            rubf返回的一個stringbuf 對象的指針,str方法返回的是一個string對象,上面的rubf也可以換成str方法。
            這三個類的str和rubf的類方法用法都一樣。
            不同的是str方法:有兩個版本:
            string str()const;//拷貝流緩沖到一個string對象中
            void str(constr string& s);//通過流緩沖構(gòu)造一個string對象。上面的rubf也可以寫出Outbuff.rubuf()->str(),這樣些效率更高些。

            需要特別注意的是:要清空上面的類對象的內(nèi)存,不能用clear方法,那只是設置了錯誤標志位,要用str("");
            stringstream的<<方法和ostream的 <<方法一樣。
            而且stringstream只有<<運算符可以用。
            ostream& operator<< (bool& val );
            ostream& operator<< (short& val );
            ostream& operator<< (unsigned short& val );
            ostream& operator<< (int& val );
            ostream& operator<< (unsigned int& val );
            ostream& operator<< (long& val );
            ostream& operator<< (unsigned long& val );
            ostream& operator<< (float& val );
            ostream& operator<< (double& val );
            ostream& operator<< (long double& val );
            ostream& operator<< (void*& val );
             
            ostream& operator<< (streambuf* sb );
             
            ostream& operator<< (ostream& ( *pf )(ostream&));
            ostream& operator<< (ios& ( *pf )(ios&));
            ostream& operator<< (ios_base& ( *pf )(ios_base&));
            上面的都是它的成員函數(shù),下面的則是全局函數(shù)
            ostream& operator<< (ostream& out, char c );
            ostream& operator<< (ostream& out, signed char c );
            ostream& operator<< (ostream& out, unsigned char c );

            ostream& operator<< (ostream& out, const char* s );
            ostream& operator<< (ostream& out, const signed char* s );
            ostream& operator<< (ostream& out, const unsigned char* s );

            我們還可以利用stringstream來清楚文件內(nèi)容。示例代碼如下:
            ofstream fs(FileName);
            stringstream str;
            str<<fs;
            fs.close();
            這樣文件就被清空了,但是文件還在。

            posted on 2009-03-16 23:51 Benjamin 閱讀(8610) 評論(0)  編輯 收藏 引用 所屬分類: 泛型編程

            色综合久久中文综合网| 人妻无码中文久久久久专区| 国内精品免费久久影院| 欧洲性大片xxxxx久久久| 狠狠色丁香婷婷久久综合五月| 亚洲国产精品无码久久久秋霞2| 精品999久久久久久中文字幕| 性做久久久久久久久| 久久国产亚洲精品麻豆| 久久久精品国产免大香伊| 国内精品伊人久久久久| 国产一区二区久久久| 日本免费久久久久久久网站| 伊人久久大香线蕉亚洲| 久久久久国产精品三级网| 国产婷婷成人久久Av免费高清| 亚洲国产婷婷香蕉久久久久久| 国产 亚洲 欧美 另类 久久| 久久久久亚洲精品无码蜜桃| 思思久久精品在热线热| 久久综合给合综合久久| 激情综合色综合久久综合| 久久久久亚洲精品天堂| 日产精品久久久一区二区| 尹人香蕉久久99天天拍| 亚洲а∨天堂久久精品9966| 国产精品美女久久久久AV福利| 99国产欧美久久久精品蜜芽| 久久久精品2019免费观看| 日产精品久久久一区二区| 亚洲国产精品久久电影欧美| 午夜精品久久久久| 国产欧美久久久精品影院| 色综合久久中文字幕综合网| 欧美粉嫩小泬久久久久久久| 香蕉久久夜色精品国产2020| 狠狠综合久久综合88亚洲| 人人狠狠综合久久88成人| 久久国产亚洲精品麻豆| 国产精品久久久久久久久久免费| 亚洲国产精品热久久|