• <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 閱讀(2111) 評論(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位
            亚洲午夜久久久久久久久久 | 东京热TOKYO综合久久精品| 日韩人妻无码一区二区三区久久99 | 91精品国产高清久久久久久io| 蜜臀av性久久久久蜜臀aⅴ| 久久人爽人人爽人人片AV| 色综合久久中文色婷婷| 亚洲人成无码www久久久| 久久亚洲精品中文字幕| 国产免费久久久久久无码| 色婷婷狠狠久久综合五月| 无码国产69精品久久久久网站| 日韩一区二区久久久久久| 久久伊人精品一区二区三区| 天天躁日日躁狠狠久久| 成人精品一区二区久久| 色8久久人人97超碰香蕉987| 精品无码久久久久久久动漫| 蜜臀av性久久久久蜜臀aⅴ| 性做久久久久久久久老女人| 97超级碰碰碰久久久久| 久久精品国产清自在天天线| 99久久er这里只有精品18| 久久夜色撩人精品国产小说| 国产精品久久久久9999| 久久久久久精品免费免费自慰 | 亚洲а∨天堂久久精品9966| 久久久www免费人成精品| 国产巨作麻豆欧美亚洲综合久久 | 久久亚洲中文字幕精品一区| 久久99毛片免费观看不卡| 久久久国产乱子伦精品作者| 伊人久久大香线蕉亚洲| 国产免费久久精品99re丫y| 午夜视频久久久久一区 | 久久国产乱子伦精品免费强| 欧美精品九九99久久在观看| 女同久久| 久久无码精品一区二区三区| 久久WWW免费人成—看片| 国产精品美女久久久m|