## Java編程那些事兒8——計算機內部的數據表達
作者:陳躍峰
出自:[http://blog.csdn.net/mailbomb](http://blog.csdn.net/mailbomb)
**1.3 計算機內部的數據表達**
計算機內部數據表達的總原則就是:把一切內容數值化、數字化。這個也是編程時處理數據的基本方式,對于編程理解的越深入,則將越認同該原則。
其實計算機也只能這樣,因為計算機內部只能存儲0和1兩個數字,所以必須把指令、數據、圖片、文本等各種各樣的內容數字化成0和1進行存儲、傳輸和顯示。
**1.3.1 整數的表達**
整數有正負之分,但是計算機內部只能存儲0和1,則計算機內部將符號數字化,用二進制碼的最高位代表符號位,規定該位為0代表正,1代表負。這就是符號數字化的規定。
前面介紹過整數在計算機內部都是以二進制的形式保存的。但是為了計算方便,以及簡化CPU的結構,所以在存儲和運算時都采用補碼的形式。
前面介紹的那些直接計算出來的二進制形式,都稱作整數的原碼。規定正數的原碼、反碼和補碼都是自身。
而對于負數,仔細研究一下其組成格式。以8位機為例,也就是一個數字占計算機中的8位,也就是一個字節,用最高位存儲符號位,其它的位存儲數值。例如-8的原碼是10001000,最高位的1代表負數,后續的7位代表數值。
負數的反碼是指符號位不變,其他的位取反,也就是0變1,1變0,則-8的反碼是11110111。
負數的補碼是指在反碼的數值位上加1,運算后得到的結果,只計算數值位,不改變符號位。則-8的補碼是11111000,該次運算中,低位向高位進行了進位。
規律:補碼的補碼等于負數的原碼。
也就是對負數的補碼再求補,則得到的負數的原碼。
熟悉整數的表達,對于后續理解數據的區間以及進行強制轉換以后得到的數值很有幫助,也是進行位運算的基礎。
備注:小數,編程語言中稱浮點數,的存儲形式和整數不同。
**1.3.2 字符的表達**
字符指計算機內部單個的符號,如標點符號、英文字母和漢字等等。因為這些字符種類各異,計算機無法直接表達,那么就采用了計算機編程中也常用的方式,對每個字符進行編號,例如規定a字符編號為97,b字符編號為98等等。
由于需要編號的字符很多,就專門規定了一系列字符和編號的對應規則,那么這些對應表就被稱作字符集,常見的字符集有ASCII、GB2312、BIG5等。
在計算機內部存儲、運算和傳輸時,都只需要使用該編號即可。
字符集比較完美的解決了字符的存儲和傳輸的問題。
所以字符在程序內部可以參與運算,其實參與運算的就是這個字符的編號,字符集規律是很多字符變換邏輯實現的基礎。
備注:字符的顯示則通過專門的字符顯示碼實現。
**1.3.3 總結**
其實計算機內部所有的東西都是以數字的形式存儲的,這里只是希望通過這兩種簡單的結構,使大家了解將數據數字化的思想,這是編程時常用的思想之一。
?
- 前言
- (1)序言
- (2)程序設計是什么?
- (3)你適合學習程序設計嗎?
- (4)如何學好程序設計?
- (5)程序設計介紹小結
- (6)計算機軟件基本概念
- (7)進制的概念
- (8)計算機內部的數據表達
- (9)網絡編程基礎
- (10)Java語言簡介
- (11)JDK的獲得、安裝和配置
- (12)第一個HelloWorld程序
- (13)Eclipse基本使用
- (14)Eclipse基礎使用進階
- (15)如何學好Java語法
- (16)代碼框架、關鍵字和標識符
- (17)基本數據類型
- (18)變量和常量
- (19)數據類型轉換
- (20)空白、語句結束和注釋
- (21)算術運算符
- (22)比較運算符
- (23)邏輯運算符
- (24)賦值運算符
- (25)位運算符
- (26)移位運算符
- (27)其它運算符
- (28)運算符優先級
- (29)表達式
- (30)流程控制基礎
- (31)if語句語法(1)
- (32)if語句語法(2)
- (33)if語句語法(3)
- (34)switch語句語法
- (35)while語句語法
- (36)do-while語句語法
- (37)for語句語法
- (38)break和continue語句
- (39)流程控制綜合示例1
- (40)流程控制綜合示例2
- (41)流程控制綜合示例3
- (42)流程控制綜合練習
- (43)數組概述
- (44)數組基礎語法
- (45)數組使用示例1
- (46)數組使用示例2
- (47)數組使用示例3
- (48)多維數組基礎
- (49)多維數組使用示例1
- (50)多維數組使用示例2
- (51)多維數組練習
- (52)方法聲明
- (53)方法聲明示例
- (54)方法調用
- (55)方法重載和參數傳遞
- (56)方法練習
- (57)面向對象基礎
- (58)類(一)
- (59)類(二)
- (60)對象
- (61)面向對象設計方法和面向對象特性(一)
- (62)繼承(二)
- (63)多態性
- (64)訪問控制符、修飾符和其它關鍵字
- (65)static修飾符
- (66)final修飾符
- (67)this和super
- (68)抽象類和接口(一)
- (69)抽象類和接口(二)
- (70)抽象類和接口(三)
- (71)內部類簡介
- (72)包的概念
- (73)JDK文檔使用
- (74)java.lang包介紹1
- (75)String類使用
- (76)StringBuffer類和System類
- (77)包裝類
- (78)時間和日期處理
- (79)Random隨機處理
- (80)集合框架簡述
- (81)異常處理概述
- (82)異常處理語法1
- (83)異常處理語法2
- (84)IO簡介
- (85)IO類體系
- (86)文件操作之File類使用
- (87)文件操作之讀取文件
- (88)文件操作之寫文件
- (89)讀取控制臺輸入
- (90)裝飾流使用1
- (91)裝飾流使用2
- (92)IO使用注意問題
- (93)多線程基礎
- (94)多線程實現方式1
- (95)多線程實現方式2
- (96)多線程使用示例1
- (97)多線程使用示例2
- (98)多線程問題及處理1
- (99)多線程問題及處理2
- (100)多線程問題及處理3
- (101)網絡編程概述
- (102)網絡編程技術1
- (103)網絡編程技術2
- (104)網絡編程技術3
- (105)網絡編程技術4
- (106)網絡編程技術5
- (107)網絡協議概念
- (108)網絡編程示例1
- (109)網絡編程示例2
- (110)網絡編程小結