作者tinlans ( )
看板C_and_CPP
標題Re: [問題] 為什麼作業系統都用C寫? 而不用C++呢?
時間Sat Mar 7 20:48:57 2009
還是不說廢話了,
直接寫程式吧,
目的是同需求下使用 virtual function 到底有沒有 overhead:
http://tinyurl.com/bcjawe
檔案裡面分別是不用 OO 寫的 C、用 OO 寫的 C、用 OO 寫的 C++,
為了公平起見我 C++ 的函式也用 C subset 提供的,
以下是我用的環境:
Intel(R) Xeon(R) CPU 5160 @ 3.00GHz
x86-64 Gentoo Linux (kernel 2.6.28-gentoo-r1)
gcc version 4.3.3 (Gentoo 4.3.3 p1.0, pie-10.1.5)
編譯參數如同裡面 makefile 只是 -O3。
各跑五次的數據 (loop 跑 500,000,000 次):
c:
1.668u 0.000s 0:01.66 100.0% 0+0k 0+0io 0pf+0w
1.668u 0.000s 0:01.66 100.0% 0+0k 0+0io 0pf+0w
1.668u 0.000s 0:01.66 100.0% 0+0k 0+0io 0pf+0w
1.668u 0.000s 0:01.66 100.0% 0+0k 0+0io 0pf+0w
1.668u 0.000s 0:01.66 100.0% 0+0k 0+0io 0pf+0w
c_oo:
1.198u 0.000s 0:01.19 100.0% 0+0k 0+0io 0pf+0w
1.180u 0.000s 0:01.18 100.0% 0+0k 0+0io 0pf+0w
1.181u 0.000s 0:01.18 100.0% 0+0k 0+0io 0pf+0w
1.179u 0.000s 0:01.18 99.1% 0+0k 0+0io 0pf+0w
1.175u 0.000s 0:01.17 100.0% 0+0k 0+0io 0pf+0w
cxx:
1.344u 0.000s 0:01.34 100.0% 0+0k 0+0io 0pf+0w
1.341u 0.001s 0:01.34 100.0% 0+0k 0+0io 0pf+0w
1.344u 0.000s 0:01.34 100.0% 0+0k 0+0io 0pf+0w
1.341u 0.000s 0:01.34 100.0% 0+0k 0+0io 0pf+0w
1.343u 0.000s 0:01.34 100.0% 0+0k 0+0io 0pf+0w
顯然用 C++ 的 OO 機制是會比 C 的 OO 慢一點
(
其實是因為我 C 的部分沒有實作出 OO 特性,
它是 static 語意 (要拔掉 union 然後用 void * 代替資料欄位),
完全模擬 OO 的話那 0.2 秒的差異馬上會不見,
有人想戰的話我再做細部實作 XD
)
但如果是我的話我會選擇寫 C++,
用 C 實現 OO 有很多人工打字的地方可能不小心犯錯造成很多困擾,
用 C++ 實現 OO 的話那些 code 都是 compiler 幫我產生,
而且我不認為有多少人會很認真的寫 c_oo 的那種寫法;
更何況本科系的人都知道 80/20 法則 (or 90/15) 及 Amdahl's law,
你只要在真正需要效能的那一小部分程式碼避開用 C++ 寫 OO 就行了,
C programmer 常常有一個通病就是他會認為每行程式碼都隨時隨地在跑,
如果是這樣的話演算法的 amortized time complexity 這套理論也可以丟了。
--
Ling-hua Tseng (uranus@tinlans.org)
Department of Computer Science, National Tsing-Hua University
Interesting: C++, Compiler, PL/PD, OS, VM, Large-scale software design
Researching: Software pipelining for VLIW architectures
Homepage:
https://www.tinlans.org
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 118.160.108.190
※ 編輯: tinlans 來自: 118.160.108.190 (03/07 21:09)
→ ggg12345:最影響OS的overhead部份才是關鍵吧!使用kernel/monitor 03/07 22:33
→ ggg12345:模式的OS(如unix),上半層的monitor用o-o概念最接近,下半 03/07 22:35
→ ggg12345:層的kernel使用C+ASM彈性最適宜,併行的虛耗都在Kernel上 03/07 22:41
→ weiyucsie:後來試著用c改寫cxx那個版本測測看(不知道有沒有寫對XD) 03/08 04:49
→ weiyucsie:結果不同機器編譯出來的相對速度不太一樣XD 03/08 04:50
→ weiyucsie:(和多核心或ht技術有關嗎?XD) 03/08 04:51
→ tinlans:跟指令集有差,還有編譯器。 03/08 13:29