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

可冰

冰,是沉睡著的水......

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  37 隨筆 :: 5 文章 :: 94 評論 :: 0 Trackbacks
大家都知道現在C/C++的編譯是分為兩個部分的,即編譯和連接:源文件經編譯后生成目標文件,然后再連接為可執行文件.
我對這兩個階段要做的工作還沒有了解,所以我現在可以這樣設想(也有可能是無知的設想):
以一種標準的方式定義目標文件的格式,使之在各操作系統上生成的目標文件完全一致,而且都可以在相應的平臺上進行正確的連接.這樣的話,就相當于是一個中間層次的可移植性了.其實,如果這樣不行的話也可以像JAVA那樣生成一定格式的"字節碼"文件,然后再進行編譯連接.
如果可以將連接的一部分功能結合到操作系統內部,實現動態的連接,這樣就可以實現類似動態裝載的特性了.
但這個要實現的話就需要有一個大的投資方或者開源社區自己的共同努力才能實現了.
所以現在這樣的想法還是空想吧.

不過我想,事物都是發展的,我們的C++當然也不會例外的.我相信C++會在不久也實現動態及完全的跨平臺的特性的.希望這一天不會太遠!
posted on 2005-09-14 23:30 可冰 閱讀(2465) 評論(7)  編輯 收藏 引用 所屬分類: C++

評論

# re: 目前C++可以實現跨平臺嗎 2005-09-18 08:39 FrameSniper
"大家都知道現在C/C++的編譯是分為兩個部分的,即編譯和連接:源文件經編譯后生成目標文件,然后再連接為可執行文件."——現在?你的意思是以前不是了?原生開發環境下誕生的程序都上兩個階段吧,一個就是編譯成目標文件,然后Linker把這些目標文件以及一些資源文件連接成最后的符合PE/COFF標準的EXE文件或者COM等可執行文件。

跨平臺的基礎是虛擬機,就我所知,VC.NET好象是可以同時對原生和基于虛擬的兩個環境做開發的。
  回復  更多評論
  

# re: 目前C++可以實現跨平臺嗎 2005-09-18 09:54 cpunion
跨平臺的一個方式是虛擬機,另一個方式是提供一致的API和ABI,也就是要求所有操作系統支持相同的可執行文件格式,完整支持POSIX,這個似乎很難達到。

所以目前看來,虛擬機是唯一的辦法。

從C++語言的發展方向上,很難看到他們有在語言層面上跨平臺的打算。

退而求其次,或許能夠依賴于某個工具,幫助檢查源代碼的可移植性。  回復  更多評論
  

# re: 目前C++可以實現跨平臺嗎 2005-09-18 11:06 可冰
@FrameSniper
"現在?你的意思是以前不是了?"
----------
當然不是了,我的文字不好,沒有講明白,謝謝你指正.

另外,我不認為跨平臺只有依靠虛擬機.像cpunion所說,只要系統提供一致的接口就行.但是,如果接口差異不是很大,我想應該可以靠編譯器的工作來轉換.
我的意思也不是要讓生成的可執行文件實現跨平臺,而是在一個中間代碼的層次實現,而后由編譯器針對各系統的不同而生成不同的程序.雖然這也不是完全的跨平臺,但在開發者的角度看也差不多了,而且可以通過編譯器的實現來將中間代碼的編譯速度提高,這樣也可以實現.NET所謂的即時編譯,即第一次運行的時候編譯,以后就不用編譯了.其實在虛擬機上,也不是可以生成目標操作系統的機器代碼嗎,但它的效率應該不及C/C++了吧.


  回復  更多評論
  

# re: 目前C++可以實現跨平臺嗎 2005-09-18 11:19 可冰
@cpunion
從C++語言的發展方向上,很難看到他們有在語言層面上跨平臺的打算。
--------------
確實,但我覺得現在語言層面動態的需求是很大的,尤其是做應用開發的.而C++卻是在已經做得不錯的效率上下工夫,而且現在又要加入一些保證安全的語言特征.這可不符合大勢所趨啊.所以我覺得C++也會往這方面發展的吧.
其實我覺得那些C++的元老對C++的發展起了太大的作用,而他們又是比較保守的,所以導致C++發展緩慢.我覺得現在JAVA的方式不錯,通過JCP社區最終決定它的發展方向.
也許也是我錯了吧:也許C++并不想走"大眾化"的道路,或是那些元老不想讓它走.
但我認為使用者才是擁有最終決定權的.  回復  更多評論
  

# re: 目前C++可以實現跨平臺嗎 2005-09-18 12:55 cpunion
C/C++代碼有很多方面在跨平臺時有問題,并不是JIT編譯器可以解決的,主要是畎;它太底層了。

JIT本身也是虛擬機的一部分,采用它就得確定使用虛擬機。

C++跨平臺的問題,通過良好的設計和編寫規范代碼,是可以實現的,很多產品都是跨平臺的了。

C++最大的問題應該是動態性問題,C++除了虛函數和簡單的RTTI以外,基本上沒有任何動態性,而動態性卻是分布式編程中基本的需求。目前C++編寫分布式組件,都需要先以一種IDL來編寫接口,再生成一堆調用代碼,而很多其它語言則可以在語言內解決這個問題。

c++0x正在加入一個XTI(擴展類型信息),不過還沒有看到實現產品,所以也無法評論。我希望它不要像上一個標準中的RTTI這么簡單,而是要以一種語言層面的東西加入進來。
比如我在類聲明時寫成dynamic class X;則這個類在編譯后,將在全局類型表中注冊自己,并可以通過全局名稱查找到類,還可以由類查找所有成員的名稱、類型等,也就是反射,當然希望還能走得更遠些,比如動態創建、動態加載類型庫等。

愛之深,痛之切,適當抱怨一下也未嘗不可。。。  回復  更多評論
  

# re: 目前C++可以實現跨平臺嗎 2007-07-18 17:13 學習
編譯跨平臺,標準c/c++,在vc下開發嵌入式應用,很普遍的事情  回復  更多評論
  

# re: 目前C++可以實現跨平臺嗎[未登錄] 2007-08-12 01:37 南郁
你說的很有道理,“生成的目標文件完全一致”,這在C++的討論里,稱為“有共同的二進制格式”,但事實上有兩個問題:

第一: “二進制格式” 的標準,不在語言里,而在操作系統手上,可惜操作系統之間往往是沒有這個共同標準。所以只能通過編譯成一個“偽代碼”,再去調操作系統對應的功能。

第二,有了偽代碼,在去調系統對應功能時,仍然可能遇上問題。那就是各個操作系統對應功能的實現差別太大,這時簡單地“調用”就不可能了。比如有功能A,在操作系統O1上,只需要一個函數,而在操作系統O2上,需要3個函數的組合才能實現。所以這個“調用”,就得“智能”一點,這樣就成了“虛擬機”了,也就是在不同操作系統,有不同的虛擬機實現對外統一的接口。舉一個典型例子,你想吃漢堡,這時有三種情況:

1.本地有麥當勞,去麥當勞買一個,因為麥當勞的漢堡比較地道。
2.本地沒有麥當勞,但有肯德基,去肯德基買一個。
3.本地根本沒有賣漢堡的店。。。沒關系,親處去找面粉,雞肉什么的,做一個,只要你愿意等。

這些事情就是虛擬機做的。C++不考慮虛擬機,所以也就不可能有運行時機制上的跨平臺。但是C++的語法當然是跨平臺的。還有就是庫可以跨平臺。比如網絡,一個ACE庫,確實跨了很多平臺。


比如你想買一份 麥當勞的堡,但你現在所在的城市居然沒有麥當勞,那就不好辦了。。。  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美在线日韩| 欧美大片在线看免费观看| 亚洲精品日韩久久| 欧美激情精品| 一本色道久久综合亚洲精品婷婷| 亚洲六月丁香色婷婷综合久久| 老**午夜毛片一区二区三区| 久久精品人人做人人综合| 国内精品伊人久久久久av一坑| 午夜在线视频观看日韩17c| 亚洲免费视频一区二区| 国产亚洲视频在线观看| 美日韩免费视频| 女主播福利一区| 亚洲视频在线视频| 午夜一区二区三区在线观看| 在线电影国产精品| 亚洲经典自拍| 国产精品一区二区在线观看不卡 | 亚洲欧美日韩爽爽影院| 国产精品推荐精品| 男人的天堂亚洲| 欧美成人伊人久久综合网| 亚洲午夜精品一区二区| 欧美在线啊v一区| 9l国产精品久久久久麻豆| 亚洲男人的天堂在线aⅴ视频| 国产日韩欧美| 亚洲国产片色| 国产视频精品va久久久久久| 亚洲福利电影| 国产免费亚洲高清| 亚洲国产精品高清久久久| 国产精品黄视频| 欧美91大片| 国产免费成人av| 亚洲人成在线观看网站高清| 国产欧美日本一区二区三区| 亚洲第一中文字幕| 国产日韩亚洲欧美综合| 亚洲日产国产精品| 狠狠色狠狠色综合日日tαg| 夜夜嗨av一区二区三区四季av| 国产精品麻豆成人av电影艾秋 | 国外成人在线视频| 亚洲精品一品区二品区三品区| 国产精品一区二区三区观看| 欧美国产欧美亚州国产日韩mv天天看完整 | 亚洲精品乱码久久久久久久久| 久久天天躁狠狠躁夜夜av| 午夜精品成人在线| 欧美精品在线免费| 欧美成人精品在线视频| 国产亚洲欧美日韩在线一区| 一本色道久久| 一本色道久久99精品综合 | 欧美激情一区二区三区在线视频观看| 另类成人小视频在线| 久久精品日韩一区二区三区| 国产精品久久久久久户外露出| 欧美国内亚洲| 在线精品国产欧美| 久久精品99无色码中文字幕| 欧美中文字幕在线| 国产精品久久91| 亚洲视频在线观看一区| 亚洲综合色网站| 欧美性一区二区| 一区二区三区视频在线播放| 亚洲视频香蕉人妖| 欧美日韩情趣电影| 日韩视频不卡中文| 中国日韩欧美久久久久久久久| 欧美电影打屁股sp| 亚洲国产三级| 一区二区三区免费观看| 欧美日韩国产bt| 一区二区精品国产| 欧美在线观看视频在线| 国产视频综合在线| 久久久精彩视频| 欧美a级片网| 亚洲精品一区二区三区福利| 欧美大片国产精品| 一区二区精品国产| 欧美在线高清| 亚洲国产mv| 欧美日韩精品免费观看视频| 亚洲毛片一区二区| 亚洲欧美日韩精品| 国产欧美一区二区三区久久| 欧美一区二区三区日韩| 老**午夜毛片一区二区三区| 亚洲人成在线观看一区二区| 欧美激情一级片一区二区| 亚洲人人精品| 新67194成人永久网站| 国产一区白浆| 欧美jizz19性欧美| 亚洲一区三区电影在线观看| 久久国产一区二区三区| 亚洲国产一区二区视频| 欧美视频在线不卡| 久久久久久久综合| 99视频国产精品免费观看| 久久久www成人免费毛片麻豆| 国内精品视频在线播放| 欧美黄污视频| 午夜在线视频一区二区区别| 亚洲福利国产| 久久成人免费电影| 最新热久久免费视频| 国产精品久久久久久久午夜 | 一区二区三区精品视频在线观看| 中文日韩在线| 在线观看日韩精品| 国产精品入口夜色视频大尺度| 久久精品国产亚洲aⅴ| 亚洲日本视频| 久久伊人一区二区| 亚洲视频免费| 亚洲激情二区| 国产有码一区二区| 欧美理论电影网| 久久精品免费看| 在线亚洲精品| 亚洲国产视频一区二区| 久久天天躁狠狠躁夜夜爽蜜月 | 国产精品mm| 欧美高清日韩| 久久综合精品一区| 欧美一区二区网站| 亚洲手机在线| 国产精品99久久不卡二区| 91久久香蕉国产日韩欧美9色| 久久精品国产精品亚洲精品| 亚洲尤物精选| 在线亚洲美日韩| 亚洲免费电影在线观看| 亚洲国产小视频在线观看| 国产亚洲一区二区三区在线观看| 欧美午夜不卡视频| 欧美裸体一区二区三区| 欧美成人性网| 欧美成人在线影院| 欧美成人激情在线| 免费视频一区| 麻豆精品视频在线观看| 久久久在线视频| 久久久久久网站| 久久精品国产99国产精品澳门| 一区二区日本视频| 一本色道久久综合亚洲精品高清 | 日韩小视频在线观看| 亚洲区国产区| 亚洲精品一区在线| 99热这里只有精品8| 一区二区三区**美女毛片| 99视频精品全国免费| 99精品99久久久久久宅男| 在线视频欧美一区| 亚洲一区二区三区免费观看| 亚洲影院在线| 欧美在线视频一区二区| 欧美在线免费一级片| 久久亚洲精品网站| 欧美黄色免费| 国产精品h在线观看| 国产伦精品一区二区三区高清| 国产精品一区久久久| 国内一区二区三区在线视频| 亚洲国产精品第一区二区| 日韩一级免费| 性一交一乱一区二区洋洋av| 久久婷婷国产综合国色天香| 欧美成人精品高清在线播放| 亚洲日本在线视频观看| 中文精品视频| 久久九九精品| 欧美日韩国产123| 国产欧美高清| 亚洲人体一区| 亚洲欧美一区二区原创| 久久蜜桃精品| 亚洲精品久久久久久久久| 亚洲永久免费| 欧美高清hd18日本| 国产欧美日韩激情| 亚洲精品视频一区二区三区| 午夜精品久久久久久久99樱桃| 久久久999精品视频| 亚洲经典在线看| 久久国产精品久久精品国产| 欧美精品久久久久久久| 国产视频在线观看一区二区| 亚洲激情视频在线| 久久疯狂做爰流白浆xx| 亚洲精品一区二区三区av| 久久久精品动漫| 国产精品影视天天线|