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

            http://hi.baidu.com/zyb_debug/blog/item/cdfc2adf9b982451cdbf1a7e.html
            streams定義了兩個可用于布爾表達式的函數

            operator void*()   意義:stream是否出錯(相當于!fail())
            operator !()       意義:stream是否已出錯(相當于fail())

            我們可以運用operator void*()在控制結構中簡潔測出stream的當前狀態:

            while (std::cin)
            {
            }
            控制結構中的布爾條件值并不是非得直接轉換為bool不可,只要能夠轉換為某個整數型別或指針型別就夠了。
            轉換為void* 常常是為了在同一表達式中讀入對象并測試是否成功:

            if(std::cin>> x)
            {
            //reading x was successful
            }
            正如先前的討論,表達式
            std::cin >> x
            會返回cin,所以讀入x后,上述語句變為
            if(std::cin)
            {
            }

            此時的cin被用于條件判斷,所以cin會調用 operator void*,返回"stream是否發生錯誤"

            以上技術的幾個典型應用就是以循環讀入對象并處理
            while(std::cin >> obj)
            {
            std:: cout << obj << std::endl;
            }

            如果failbit或badbit被設立,該循環就立即中止---出現錯誤或者讀到(end-of-file).

            我們可以利用operator!進行相反測試,它會返回"strean是否已發生錯誤",也就是說如果failbit 或badbit被設立就會返回true用法如下:
            if(!std::cin)
            {
            //the stream is not OK
            }

            上述文字出于 <<c++標準程序庫-自修教程與參考手冊->>p600 侯捷-孟巖譯

            花了幾天時間終于將這本書閱讀完了,里面的streambuf沒有理解,是我功底不夠的緣故吧...
            開學了,人多了起來,繼續靜靜的學習

            Posted on 2009-09-06 14:38 zyb_debug 閱讀(2106) 評論(3)  編輯 收藏 引用

            Feedback

            # re: 關于while(cin)  回復  更多評論   

            2009-09-06 19:06 by OwnWaterloo
            >> 控制結構中的布爾條件值并不是非得直接轉換為bool不可,只要能夠轉換為某個整數型別或指針型別就夠了。

            選void* 而不是整數類型是有原因的。 可以避免如下代碼被編譯通過:
            cin<< xxx;


            streambuf是重點之一。
            istream 負責格式化輸入, ostream負責格式化輸出。
            streambuf 如其名那樣, 作為格式化結果與最終輸出目的地之間的緩存。

            而stringstream, fstream, 沒有太多的功能。
            格式化功能是繼承自iostream。
            而它們使用的是stringbuf, filebuf, 是streambuf的子類, 提供一些額外功能。
            stringstream, fstream比iostream多的功能, 正是其buf提供的。

            # re: 關于while(cin)  回復  更多評論   

            2009-09-06 20:16 by zyb_debug
            @OwnWaterloo
            恩 istream ostream里面的文件讀取主要是通過streambuf,維護這個東西實現的。
            我估計是閱讀的太快了,總是感覺有些理解不了。
            而且我現在讀取文件數據都用的是XML,IO這塊沒費心。
            其實我覺得最有用的是STL里的算法和容器

            # re: 關于while(cin)  回復  更多評論   

            2009-09-09 23:39 by Chuck
            傳說有一個版本的cin中是這么來處理轉換的

            operator int ();

            int i;
            while ( cin>>i ) {}

            那么這一句就會被編譯為 cin這個整數值 右移 i位
            久久久久综合国产欧美一区二区| 狠狠色丁香婷婷久久综合五月| 一本色道久久99一综合| 欧美丰满熟妇BBB久久久| 一级做a爰片久久毛片16| 久久av免费天堂小草播放| 久久乐国产综合亚洲精品| 亚洲中文字幕久久精品无码喷水| 精品久久久久久久无码| 人妻中文久久久久| 久久狠狠色狠狠色综合| 亚洲精品无码久久一线| 久久精品国产精品亚洲人人| 国内高清久久久久久| 精品久久久无码中文字幕| 久久亚洲精品成人AV| 99蜜桃臀久久久欧美精品网站| 99久久无码一区人妻| 久久精品国产清高在天天线| 久久久久99精品成人片三人毛片| 国内精品久久久久久99蜜桃| 精品国产青草久久久久福利| 亚洲欧美日韩精品久久亚洲区| 国产99久久久久久免费看| 91精品国产综合久久精品| 久久人妻少妇嫩草AV蜜桃| 色8激情欧美成人久久综合电| 国产精品热久久无码av| 国产AⅤ精品一区二区三区久久| 77777亚洲午夜久久多喷| 久久久久免费看成人影片| 久久免费看黄a级毛片| 日本精品一区二区久久久 | 91久久精品国产成人久久| 久久精品国产第一区二区三区| 无码人妻精品一区二区三区久久久 | 久久久久免费精品国产| 久久久久亚洲精品日久生情| 亚洲精品国产自在久久| 久久无码AV中文出轨人妻| 久久亚洲电影|