C 中的整數:一點歷史
整數是計算中最基本的資料結構-如果我們甚至可以稱它們為「結構」的話。身為程式設計師,我們的工作就是賦予這些數字意義。無論軟體多麼複雜:最終它只是一個整數,而你的處理器只能理解整數。
如果我們需要負數,我們發明了二進位補碼。如果我們需要小數,我們會創建一種科學記數法,然後——砰——我們就有了一個浮點數。歸根究底,還是無法逃避零和一。
整數的小歷史
在C中,int幾乎是自然型。儘管編譯器可能會抱怨,但到處都有一些標誌,大多數都會允許你寫這樣的東西:
main(void) { return 0; }
從技術上講,這與:
int main(void) { return 0; }
這種行為來自於當時的常識:如果程式設計師沒有指定類型,則預設為整數是合理的。
C 的設計就是考慮到了這個想法。最初,int 沒有標準大小。 PDP-11 處理器(最初建立 C 的機器)使用 16 位元定址。因此,我們假設 int 也是 16 位元才有意義。這個想法是,int 的大小會隨著處理器的發展而成長。
神秘的尺寸
這種方法產生了一些問題。如果 int 的大小因平台而異,則為不同處理器編譯的程式的行為可能會有所不同。這打破了 C 是一種「不可知論」語言可以編譯成不同架構的想法。
與 int 不同,例如,char 總是具有明確定義的大小:8 位,有符號。儘管有它的名字,char 並不是文字字元的抽象類型。它只是一個 8 位數。例如,文字「a」在編譯時轉換為數字 97,簡單明了。
其他類型呢,例如短的和長的?這個想法很簡單:
short <= int <= long
編譯器實現者可以完全自由地決定具體大小。
ANSI C (1989) 帶來了一些秩序
根據ANSI C標準,建立了一些規則:
- 字元:至少 8 位元
- 短:至少 16 位
- int:short 或更大的大小(16 或 32 位元)
- 長:至少 32 位
這個組織有所幫助,但至少可以說 int 的大小仍然令人困惑。 C99 標準引入了 stdint.h 標頭,情況有所改善。
現在我們有固定大小的種類:
- int8_t:8 位元
- int16_t:16位元
- int32_t:32位元
- int64_t:64位元
從那時起,編譯器就需要用固定大小的型別來實現這個頭。
整數的目前狀態
如今,使用 GCC 和 Clang 等現代編譯器,大小更可預測:
Type | Size |
---|---|
char | 8 bits |
short | 16 bits |
int | 32 bits |
long | 64 bits (32 bits on 32-bit systems) |
long long | 64 bits |
雖然long long還是有些奇特,但至少帶來了一些一致性(說實話,我甚至覺得long long很時尚)。
怎麼辦?
今天,我們已經配備了像 stddef.h 和 stdint.h 這樣的標頭。僅在必要時使用 int,例如 main 函數的傳回類型。對於原型以外的任何內容,最好使用 stdint.h 中的固定大小整數,對於數組索引或循環,請使用 stddef.h 中的 size_t。我希望這能讓您免去一些麻煩。
謝謝您堅持到這裡 — 下次見!
以上是C 中的整數:一點歷史的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

C#和C 的歷史與演變各有特色,未來前景也不同。 1.C 由BjarneStroustrup在1983年發明,旨在將面向對象編程引入C語言,其演變歷程包括多次標準化,如C 11引入auto關鍵字和lambda表達式,C 20引入概念和協程,未來將專注於性能和系統級編程。 2.C#由微軟在2000年發布,結合C 和Java的優點,其演變注重簡潔性和生產力,如C#2.0引入泛型,C#5.0引入異步編程,未來將專注於開發者的生產力和雲計算。

C 和XML的未來發展趨勢分別為:1)C 將通過C 20和C 23標準引入模塊、概念和協程等新特性,提升編程效率和安全性;2)XML將繼續在數據交換和配置文件中佔據重要地位,但會面臨JSON和YAML的挑戰,並朝著更簡潔和易解析的方向發展,如XMLSchema1.1和XPath3.1的改進。

C 持續使用的理由包括其高性能、廣泛應用和不斷演進的特性。 1)高效性能:通過直接操作內存和硬件,C 在系統編程和高性能計算中表現出色。 2)廣泛應用:在遊戲開發、嵌入式系統等領域大放異彩。 3)不斷演進:自1983年發布以來,C 持續增加新特性,保持其競爭力。

C 多線程和並發編程的核心概念包括線程的創建與管理、同步與互斥、條件變量、線程池、異步編程、常見錯誤與調試技巧以及性能優化與最佳實踐。 1)創建線程使用std::thread類,示例展示瞭如何創建並等待線程完成。 2)同步與互斥使用std::mutex和std::lock_guard保護共享資源,避免數據競爭。 3)條件變量通過std::condition_variable實現線程間的通信和同步。 4)線程池示例展示瞭如何使用ThreadPool類並行處理任務,提高效率。 5)異步編程使用std::as

C#和C 的学习曲线和开发者体验有显著差异。1)C#的学习曲线较平缓,适合快速开发和企业级应用。2)C 的学习曲线较陡峭,适用于高性能和低级控制的场景。

C 通過第三方庫(如TinyXML、Pugixml、Xerces-C )與XML交互。 1)使用庫解析XML文件,將其轉換為C 可處理的數據結構。 2)生成XML時,將C 數據結構轉換為XML格式。 3)在實際應用中,XML常用於配置文件和數據交換,提升開發效率。

C 學習者和開發者可以從StackOverflow、Reddit的r/cpp社區、Coursera和edX的課程、GitHub上的開源項目、專業諮詢服務以及CppCon等會議中獲得資源和支持。 1.StackOverflow提供技術問題的解答;2.Reddit的r/cpp社區分享最新資訊;3.Coursera和edX提供正式的C 課程;4.GitHub上的開源項目如LLVM和Boost提陞技能;5.專業諮詢服務如JetBrains和Perforce提供技術支持;6.CppCon等會議有助於職業

現代C 設計模式利用C 11及以後的新特性實現,幫助構建更靈活、高效的軟件。 1)使用lambda表達式和std::function簡化觀察者模式。 2)通過移動語義和完美轉發優化性能。 3)智能指針確保類型安全和資源管理。
