C語言數據類型是如何被大多數計算機系統所支持?

jopen 9年前發布 | 12K 次閱讀 C語言 C/C++開發

問題:

在讀K&R版的The C Programming Language一書時,我在[介紹,第3頁]看到這樣一條說明:

因為C語言提供的數據類型和控制結構可以直接被大部分計算機系統所支持,所以在實現自包含程序時所需要的運行庫文件一般很小。

這段黑體說明了什么?能否找到一個例子來說明C語言中的某種數據類型或控制結構不被某種計算機系統直接支持呢?

C語言數據類型是如何被大多數計算機系統所支持?

回答:

事實上,C語言中確實有不被直接支持的數據類型。

在許多嵌入式系統中,硬件上并沒有浮點運算單元。因此,如果你寫出下面的代碼:

float x = 1.0f, y = 2.0f;
return x + y;

可能會被轉化成下面這種形式:

unsigned x = 0x3f800000, y = 0x40000000;
return _float_add(x, y);

然后編譯器或標準庫必須提供'floatadd()'的具體實現,這會占用嵌入式系統的內存空間。依此去計算代碼在某個微型系統(譯者注:也就是指微型嵌入式系統)的實際字節數,也會發現有所增加。

另一個常見的例子是64位整型數(C語言標準中'long long'類型是1999年之后才出現的),這種類型在32位系統上也不能直接使用。古董級的SPARC系統則不支持整型乘法,所以在運行時必須提供乘法的實現。當然,還有一些其它例子。

其它語言

相比起來,其它編程語言有更加復雜的基本類型。

比如,Lisp中的symbol需要大量的運行時實現支持,就像Lua中的table、Python中的string、Fortran中的array,等等。在C語言中等價的類型通常要么不屬于標準庫(C語言沒有標準symbol或table),要么更加簡單,而且并不需要那么多的運行時支持(C語言中的array基本上就是指針,以NULL結尾的字符串實現起來也很簡單)。

控制結構

異常處理是C語言中沒有的一種控制結構。非局部的退出只有'setjmp()'和'longjmp()'兩種,只能提供保存和恢復某些部分的處理器狀態。相比之下,C++運行時環境必須先遍歷函數調用棧,然后調用析構函數和異常處理函數。


via:stackoverflow

作者:Dietrich Epp 譯者:KayGuoWhu 校對:wxy

本文由 LCTT 原創翻譯,Linux中國 榮譽推出

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!