• <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>
            Oo緣來是你oO


            人本是人,不必刻意去做人;世本是世,無須精心去處世;自然的才是快樂的。

            posts - 11,comments - 8,trackbacks - 0
                                                      < iostream > 和 < iostream.h > 的區(qū)別

            關鍵詞:< iostream > 和 < iostream.h >
             
            你寫程序的時候,用< iostream >還是< iostream.h >?
            你知道它們有什么區(qū)別么?還是認為他們根本就是一樣的?
            下面聽我給你吹(文中純屬個人言論,不涉及國家機密,請放心閱讀,若轉載請注明出處作者^-^)
                                          ---majianan
             
             
            其實沒有< iostream.h >這樣的東西 --- 標準化委員會在簡化非C標準頭文件時用< iostream > 取代了它。但又沒有完全取消< iostream.h >的使用,并且很多編譯器都同時支持< iostream >和< iostream.h >,造成現(xiàn)在的局面,老大(標準化委員會)確實有不得已的苦衷。
             
            話說當年,在標準化委員會動手重建新的標準庫的時候,遇到了問題。為了避免類名函數(shù)名的沖突問題,引入了名字空間std,但無數(shù)現(xiàn)有的C++代碼都依賴于使用了多年的偽標準庫中的功能,例如,聲明在< iostream.h >和< complex.h >等頭文件中的功能。現(xiàn)有軟件沒有針對使用名字空間而進行相應的設計或者升級,如果用std來包裝標準庫導致現(xiàn)有代碼不能使用,那手底下的小弟(程序員)是不會同意的。
             
            標準化委員會為了拉攏人心,吸引更多的人入會,決定為包裝了std的那部分標準庫構建新的頭文件名。將現(xiàn)有C++頭文件名中的.h去掉,所以就出現(xiàn)了< iostream.h>和< iostream >等很多雙胞胎。對于C頭文件,采用同樣方法但在每個名字前還要添加一個C,所以C的<string.h>變成了<cstring>。
             
            舊的C++頭文件是官方明確反對使用的,但舊的C頭文件則沒有(以保持對C的兼容性)。其實編譯器制造商不會停止對客戶現(xiàn)有軟件提供支持,所以在可以預計的將來,舊的C++頭文件還會囂張一段時間。
             
            如果能明白字符串頭文件的使用,舉一反三,其他的也差不多會用了。
             
            <string.h>是舊的C頭文件,對應的是基于char*的字符串處理函數(shù);
            <string>是包裝了std的C++頭文件,對應的是新的strng類;
            <cstring>是對應舊的C頭文件的std版本。
             
            好像跑遠了,言歸正傳。如果你的編譯器都同時支持< iostream >和< iostream.h >,那使用#include < iostream >,得到的是置于名字空間std下的iostream庫的元素;如果使用#include < iostream.h >,得到的是置于全局空間的同樣的元素。在全局空間獲取元素會導致名字沖突,而設計名字空間的初衷正是用來避免這種名字沖突的發(fā)生。還有,打字時< iostream >比< iostream.h >少兩個字,所以我會使用< iostream > ^-^
             
            困了,睡了。
             
             
                                                  馬嘉楠
                                              2005-12-26 午夜
            posted on 2006-08-26 09:49 馬嘉楠 閱讀(3828) 評論(5)  編輯 收藏 引用 所屬分類: 【01】C++

            FeedBack:
            # re: iostream 和 iostream.h 的區(qū)別
            2006-08-26 15:31 | keyws
            “還有,打字時< iostream >比< iostream.h >少兩個字,所以我會使用< iostream > ”
            這種說法根本不通,.h少打兩字,那相應得cout,cin每個地方都要使用std::的,這豈不得補償失?
            那你可能說加上using namespace std;,那多了可不是兩個字。


              回復  更多評論
              
            # re: iostream 和 iostream.h 的區(qū)別
            2006-09-02 00:32 | 踏雪赤兔
            若是原創(chuàng)可以理解。但還沒到值得轉載的級別  回復  更多評論
              
            # re: iostream 和 iostream.h 的區(qū)別
            2006-09-21 04:15 | 表面粗糙度輪廓儀
            不看好這個@_@~~  回復  更多評論
              
            # re: iostream 和 iostream.h 的區(qū)別
            2007-04-29 14:36 | 篷篙人
            看了之后明白了
            編譯的時候,用.h和沒有.h的有問題
            不知道為什么
            看了恍然大悟
            還是用標準的<iostream>
            程序就是要注重規(guī)范
            哲篇文章很有用  回復  更多評論
              
            # re: iostream 和 iostream.h 的區(qū)別
            2009-03-06 12:55 | 白白海
            剛學 看不懂
              回復  更多評論
              
            久久精品黄AA片一区二区三区| 久久中文精品无码中文字幕| 久久精品免费一区二区| 午夜精品久久久久久久| 色综合久久天天综合| 亚州日韩精品专区久久久| 久久久久久久亚洲Av无码| 久久国产视屏| 久久精品人人做人人爽97| 久久久不卡国产精品一区二区 | 2021久久国自产拍精品| 狠狠人妻久久久久久综合蜜桃| 久久久久99这里有精品10 | 国产亚洲成人久久| 久久影院综合精品| 无码任你躁久久久久久老妇App| 曰曰摸天天摸人人看久久久| 久久久久青草线蕉综合超碰 | 久久久国产99久久国产一| 国产精品成人精品久久久| 2021精品国产综合久久| 亚洲欧洲久久av| 亚洲午夜福利精品久久| 久久影院亚洲一区| 久久香蕉国产线看观看猫咪?v| 久久久久国产精品| 久久国产免费观看精品3| 无码AV中文字幕久久专区| 久久伊人五月丁香狠狠色| 久久婷婷五月综合成人D啪| 久久久久99精品成人片三人毛片| 免费观看成人久久网免费观看| 久久人爽人人爽人人片AV| 亚洲国产精品久久电影欧美| 久久久久久久精品妇女99| 久久综合久久美利坚合众国| 久久精品国产亚洲AV不卡| 久久精品国产亚洲av麻豆图片| 99久久精品免费看国产一区二区三区 | 久久久精品人妻一区二区三区四 | 99久久精品日本一区二区免费|