青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

統(tǒng)計

  • 隨筆 - 50
  • 文章 - 42
  • 評論 - 147
  • 引用 - 0

留言簿(6)

隨筆分類

文章分類

Link

搜索

  •  

積分與排名

  • 積分 - 166566
  • 排名 - 159

最新評論

閱讀排行榜

評論排行榜

【轉(zhuǎn)】C Runtime Library 的來歷, API, STL, MFC, ATL關(guān)系

 剛接觸Windows開發(fā)時,為了快速入門查了不少資料,沒想到看的越多,腦袋越糊涂。因為寫同一種功能的程序,找到的例程風格截然不同。拿C程序來說,有些API的名稱都很長,都是沒見過的變量類型而且全大寫;有些跟熟悉的Linux環(huán)境C開發(fā)差不多,標準短小的C函數(shù)名。再比如某些C++程序,用的標準類也會有不同。后來專門花了點功夫,才了解Windows平臺下的開發(fā)有多個不同的體系:標準C,Windows API,MFC,STL。這些都是預(yù)先編寫好的庫,實際開發(fā)時選哪個,取決于項目的規(guī)模和性質(zhì)、程序的風格,還有個人的喜好。

一、自由世界中的C\C++

1. CRT

運行時庫就是C Run-Time Library,是C而非C++語言世界的概念。取這個名字就是因為你的C程序運行時需要這些庫中的函數(shù)。

C語言是所謂的“小內(nèi)核”語言,就其語言本身來說很小(不多的關(guān)鍵字,程序流程控制,數(shù)據(jù)類型等);所以,C語言內(nèi)核開發(fā)出來之后, Dennis Ritchie 和 Brian Kernighan 就用C本身重寫了 90% 以上的 UNIX 系統(tǒng)函數(shù),并且把其中最常用的部分獨立出來,形成頭文件和對應(yīng)的 LIBRARY,C run-time library 就是這樣形成的。

隨后,隨著C語言的流行,各個C編譯器的生產(chǎn)商/個體/團體都遵循老的傳統(tǒng),在不同平臺上都有相對應(yīng)的 Standard Library,但大部分實現(xiàn)都是與各個平臺有關(guān)的。由于各個C編譯器對C的支持和理解有很多分歧和微妙的差別,所以就有了ANSI C;ANSI C(主觀意圖上)詳細的規(guī)定了 C 語言各個要素的具體含義和編譯器實現(xiàn)要求,引進了新的函數(shù)聲明方式,同時訂立了 Standard Library 的標準形式。所以C運行時庫由編譯器生產(chǎn)商提供。至于由其他廠商/個人/團體提供的頭文件和庫函數(shù),應(yīng)當稱為第三方 C 運行庫(Third party C run-time libraries)。

C Run-Time Library里面含有初始化代碼,還有錯誤處理代碼(例如divide by zero處理)。你寫的程序可以沒有 math庫,程序照樣運行,只是不能處理復雜的數(shù)學運算,不過如果沒有了C Run-Time Library,main()就不會被調(diào)用,exit()也不能被響應(yīng)。因為C Run-Time Library包含了C程序運行的最基本和最常用的函數(shù)。

2. Standard C++ Library

到了 C++ 世界里,有另外一個概念:Standard C++ Library,它包括了上面所說的C Run-Time Library和STL。包含C Run-Time Library的原因很明顯,C++ 是 C 的超集,沒有理由再重新來一個 C ++ run-time library。VC針對C++ 加入的Standard C++ Library主要包括:LIBCP.LIB, LIBCPMT.LIB和 MSVCPRT.LIB。

二、Microsoft的C\C++

1. Windows中的CRT

CRT原先是指Microsoft開發(fā)的C Runtime Library,用于操作系統(tǒng)的開發(fā)及運行。后來在此基礎(chǔ)上開發(fā)了C++ Runtime Library,所以現(xiàn)在CRT是指Microsoft開發(fā)的C/C++ Runtime Library。在VC的CRT/SRC目錄下,可以看到CRT的源碼,不僅有C的,也有C++的。

CRT原先的目的就是支持操作系統(tǒng)的運行。因為Windows操作系統(tǒng)除匯編部分外,都是用C/C++編寫的,所以內(nèi)核及許多關(guān)鍵服務(wù)都在CRT上運行(它們都采用dll技術(shù)動態(tài)鏈接)。此外,用 VC編寫的C/C++程序也用到它們(可以動態(tài)鏈接,也可以靜態(tài)鏈接,前者運行時需要系統(tǒng)中已安裝CRT的dll,后者不需要)。可以說,CRT就是 Microsoft編寫Windows時使用的低層類庫。然后,它又被當作C++標準庫的一個實現(xiàn)包含在了VC系列中;我們在VC中使用的C++標準庫,其實就是CRT的一個真子集(少了C++標準所不包含的代碼,特別是大量的低層C代碼)

C++標準,是C++的通用語言規(guī)范,指導所有C ++使用者。而CRT的其中一部分可以看作是Microsoft開發(fā)的一個C++標準庫實現(xiàn)(其實也確實如此,Microsoft在開發(fā)CRT時,參考了正在標準化過程中的C++語言規(guī)范)。它與C++標準有一定的差距,部分原因是,在C++沒有完成標準化之前,CRT已經(jīng)開發(fā)并投入使用了。為了向下兼容以前的Windows代碼,早期的CRT與C++標準總有一定的差距。但是CRT確實在不斷的改進中。VC6帶的CRT與C++標準還有比較大的差距,而 VC8的幾乎完全符合C++標準了。

2. Windows中的CRT與Windows API

至于CRT與WINDOWS API的關(guān)系,與許多人理解的相反,WINDOWS API作為Windows的一部份,是在CRT的基礎(chǔ)上開發(fā)的。你可以將Windows(及其API)看作一個項目,而這個項目使用的語言是匯編/C/C ++,使用的類庫就是CRT。所以,離開CRT,Windows API也無法使用的。

在編寫操作系統(tǒng)時,你需要一個合適的低層庫,以便完成一些基本的、多次重復的工作。于是,就有了CRT。在最低層的時候,根本連DLL這個概念都沒有的,所以CRT的源代碼只能做成lib,被靜態(tài)鏈接。然后,隨著Windows越做越復雜,Microsoft提出了API的概念,它提供Windows開發(fā)者一組接口,可以直接操作Windows,這就是Windows API了。當然,Windows API也是在CRT之上編寫的。

接著,Microsoft想給予C/C++程序員以足夠的支持,除了原始CRT之外,還要增加在Windows平臺上編程所特有的東西,如thread等等。這些東西都是和平臺相關(guān)的,只能建立在Windows API上。而這些新增內(nèi)容,也被放進了CRT中。此時,CRT不僅僅包含最低層平臺無關(guān)的代碼,還包括平臺相關(guān)的部分。如你調(diào)用CRT的 _beginthread,其實內(nèi)部調(diào)用了Windows API的CreateThread。加入這些東西后,CRT仍然被用作編寫操作系統(tǒng);但是顯然,那些調(diào)用了Windows API的部分已經(jīng)失去移值性了。

然后,CRT被封裝成產(chǎn)品,隨編譯器一起發(fā)布。此時CRT產(chǎn)品的LIB和DLL都是Windows格式的,你不能在Windows以外的平臺上使用EXE或DLL吧,這就是CRT和CRT產(chǎn)品的區(qū)別。Windows API的產(chǎn)品,或是Windows的其他許多組成部分也是一些LIB/DLL文件,這些都是表面的東西,是與Windows綁定在一起的。但是,如果你認為是先有Windows或Windows API,才有CRT的,那你就本末倒置了。除非你對CRT的定義就是那些LIB/DLL產(chǎn)品,而不包括用來產(chǎn)生它們的代碼。

當然,CRT的一些組成部分也調(diào)用了Windows API。這可能就是有人認為CRT是建立的Windows API基礎(chǔ)上的原因。但是實際上,這一部分剝離CRT沒有任何的問題。只不過Microsoft將在Windows平臺上可以使用的C/C++低層庫都加入到CRT中。因此,CRT中很大一部分是操作系統(tǒng)平臺無關(guān)的(原始的CRT),是開發(fā)Windows本身及其上一切的基礎(chǔ)。它們也可以作為一個C/C+ +庫在其他操作系統(tǒng)平臺上使用。還有一部分,則是和Windows緊密綁定的,調(diào)用Windows API來實現(xiàn)的,可以看作擴展的CRT。之所以將這兩部分放在一起,是因為它們都是開發(fā)Windows操作系統(tǒng)所需要的,也因為它們也都是Windows 平臺上的C/C++程序員所需要的。這種復雜關(guān)系是Microsoft的人為因素造成的,不能因此認為CRT是建立在Windows或Windows API基礎(chǔ)上的。

綜上,CRT(Microsoft's C/C++ Runtime Library)的一個真子集(主要是C++ Runtime Library)是一個符合(或至少是企圖符合)C++標準的C++庫。而Windows API(以及Windows的其他許多部分)都是在CRT的基礎(chǔ)上開發(fā)的。

最后再說一句,C++當然不是Microsoft的專利。但是Microsoft選擇了C++,并取得了成功,這是肯定的了:象CRT,象VC,象Windows,象Office,象 SQL Server等等。這一方面說明了C++的優(yōu)勢,一方面也是Microsoft自身的因素在起作用。然后,它當然要緊抓C++的大旗,大力宣揚它自己的C++,并排斥其他的C++。這就是帝國的“風范”了。所以對Microsoft,總是即恨且愛,總希望哪天它會良心發(fā)現(xiàn)——當然這只是幻想罷了。不過,肯定該肯定的,否定該否定的,總是應(yīng)該的。但就產(chǎn)品而言,Microsoft不是最好的,但大多都是最成功的,在看到它的不足的同時,也要看到它的優(yōu)點。存在的即使不是合理的,也一定有它的合理性。所以,不能簡單用一兩句話評價Microsoft及它的成功。惟有一點是可以肯定的,它決定選擇C ++,真是太英明了!

原帖連接:

http://leowzj1985.spaces.live.com/blog/cns!5552BF8B7C951399!306.entry

 

本文來自CSDN博客,轉(zhuǎn)載請標明出處:http://blog.csdn.net/MoonAndWind/archive/2009/07/03/4320022.aspx

posted on 2009-08-11 15:29 pear_li 閱讀(902) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            99精品视频免费观看视频| 欧美午夜电影一区| 亚洲人成网站影音先锋播放| 欧美亚洲在线播放| 久久精品视频va| 欧美大片免费观看| 亚洲国产精品福利| 99re66热这里只有精品3直播| 一区二区三区日韩精品视频| 亚洲夜晚福利在线观看| 亚洲欧美日韩精品一区二区| 欧美影院精品一区| 免费观看成人| 国产精品成人播放| 国产欧美一区二区精品性| 一区二区三区在线视频观看| 亚洲国产三级| 亚洲欧美日韩综合| 久久永久免费| 亚洲免费观看高清完整版在线观看熊 | 久久精品日产第一区二区| 久久综合久久久| 亚洲人成亚洲人成在线观看图片| 一区二区不卡在线视频 午夜欧美不卡在| 亚洲天堂男人| 你懂的亚洲视频| 国产精品色婷婷久久58| 在线观看91久久久久久| 亚洲一区二区三区免费观看| 久久久www成人免费精品| 亚洲国产精品久久久久秋霞影院 | 夜夜嗨av一区二区三区免费区| 小黄鸭精品密入口导航| 亚洲第一中文字幕| 欧美一区91| 欧美日韩视频在线第一区| 国产综合久久| 亚洲一区二区黄| 欧美成人一区二区三区在线观看| 一本色道久久综合亚洲精品高清| 毛片基地黄久久久久久天堂| 国产精品自拍在线| 亚洲一区精品电影| 亚洲欧洲美洲综合色网| 久久视频在线看| 国产有码一区二区| 欧美一区二区三区视频免费| 亚洲精品一线二线三线无人区| 久久久另类综合| 国产一区视频观看| 亚洲视频欧美在线| 午夜欧美大片免费观看| 亚洲成人在线网站| 久久蜜桃精品| 一区二区三区在线视频免费观看| 亚洲欧美视频在线观看| 亚洲天堂成人在线视频| 国产精品免费视频xxxx| 亚洲欧美精品在线| 亚洲午夜女主播在线直播| 国产精品r级在线| 亚洲小视频在线观看| 国产一区二区毛片| 午夜精品免费视频| 亚洲欧美日韩在线综合| 国产精品久久久久久久久免费桃花| 一区二区免费看| 99综合视频| 国产精品入口麻豆原神| 香蕉成人伊视频在线观看| 亚洲字幕在线观看| 好吊色欧美一区二区三区四区| 久久久久免费视频| 裸体一区二区三区| 洋洋av久久久久久久一区| 99精品国产99久久久久久福利| 国产精品成人v| 久久久精品五月天| 蜜月aⅴ免费一区二区三区| 亚洲久久一区| 亚洲一区免费| 亚洲第一二三四五区| 亚洲国产另类精品专区| 欧美体内she精视频| 欧美综合激情网| 久热精品在线视频| 亚洲一区二区不卡免费| 欧美一区二区三区久久精品茉莉花 | 日韩一级精品视频在线观看| 日韩视频精品| 国产亚洲一区二区三区在线播放| 欧美成人免费小视频| 欧美日韩在线播放三区| 久久久亚洲精品一区二区三区 | 亚洲在线免费观看| 国产在线高清精品| 亚洲欧洲一区| 国产日韩精品一区二区浪潮av| 久久综合一区| 国产精品v欧美精品∨日韩| 久久久噜噜噜| 国产精品盗摄一区二区三区| 欧美成年人网| 欧美成人tv| 国产精品免费视频观看| 亚洲一级黄色| 久久在线免费观看视频| 亚洲欧美日韩国产综合在线 | 亚洲人成网站在线播| 亚洲性感激情| 日韩午夜在线| 久久午夜国产精品| 欧美在线观看视频| 欧美日韩国产影院| 欧美二区在线观看| 国产日韩欧美三级| 亚洲少妇最新在线视频| 亚洲美女福利视频网站| 久久免费99精品久久久久久| 久久精品99国产精品| 国产精品青草综合久久久久99| 亚洲人精品午夜在线观看| 亚洲高清成人| 久久久噜噜噜久久久| 久久婷婷麻豆| 国产丝袜一区二区三区| 亚洲免费影院| 欧美亚洲综合网| 国产精品久久激情| 日韩一区二区福利| 一区二区三区日韩在线观看| 欧美国产日韩一区| 亚洲国产成人午夜在线一区 | 久久精品理论片| 欧美高清不卡| 在线精品国精品国产尤物884a| 欧美一区二区免费视频| 欧美亚洲日本国产| 国产乱码精品一区二区三区av| 亚洲无线一线二线三线区别av| 亚洲一区二区三区色| 国产精品久久久久久久久久ktv | 最新中文字幕亚洲| 亚洲美女在线一区| 欧美视频一区二区在线观看 | 欧美v亚洲v综合ⅴ国产v| 免费影视亚洲| 亚洲理伦在线| 欧美婷婷久久| 午夜免费久久久久| 久久一二三区| 日韩一区二区精品在线观看| 欧美精品免费看| 亚洲午夜小视频| 久久久久久国产精品一区| 韩国女主播一区| 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲人成人一区二区三区| 欧美精品免费在线观看| 中文久久乱码一区二区| 亚洲国产日韩精品| 国产区精品在线观看| 欧美一进一出视频| 欧美电影电视剧在线观看| 亚洲乱码一区二区| 国产精品r级在线| 欧美在线观看视频一区二区三区| 乱人伦精品视频在线观看| 夜夜嗨av一区二区三区四季av| 国产精品视区| 欧美高清视频免费观看| 亚洲一区免费网站| 欧美黄色一级视频| 亚洲一区二区三区四区五区黄| 在线视频日韩| 老司机凹凸av亚洲导航| 中日韩在线视频| 精品福利av| 欧美性色aⅴ视频一区日韩精品| 欧美一区二区三区在线免费观看| 欧美激情精品久久久久久变态| 亚洲欧美日韩国产精品| 亚洲黄色av| 国产在线拍揄自揄视频不卡99| 欧美精品一区二区三区视频| 久久国产主播| 亚洲自拍电影| 亚洲天堂av在线免费| 亚洲人成网站在线观看播放| 久久一区国产| 久久久久国产精品人| 午夜精品久久久久久久久久久久久| 亚洲激情网站| 亚洲成人在线网站| 国产揄拍国内精品对白| 国产日韩久久| 国产欧美视频一区二区三区| 欧美日韩色婷婷| 欧美激情麻豆| 免费观看一区|