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

XY

沒有任何借口
posts - 9, comments - 31, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

深入理解計算機系統2_信息存儲

Posted on 2008-10-11 22:22 路緣 閱讀(2119) 評論(0)  編輯 收藏 引用 所屬分類: 系統體系
  1.1.1.    信息存儲

計算機處理、存儲的信息都是以二值符號表示的。這些二值數字,也就是位(bit),當獨取一個出來,可能就沒有什么意義,但是把位組合到一起,加上某種解釋,就能夠表示我們想要表示的信息了。這里的按位組合,某種解釋,其實就是編碼方式。我們先來看三種最重要的數字編碼:

無符號(unsigned)編碼,傳統二進制表示法,表示大于或等于零的數字

二進制補碼(two’s-complement)編碼,表示有符號整數最常見的方式。

浮點數(floating-point)編碼,表示實數的科學計數法以2為基數的版本。

計算機用有限的位來對一個數字編碼,當運算的結果超出表示的范圍時,運算就會導致溢出。

1.1.1.1.          基本概念:

字節:計算機中8位的塊,最小的可尋址的存儲器單位。

虛擬存儲器:機器級程序把存儲器視為一個非常大的字節數組。

地址:存儲器的每個字節都有一個唯一的數字來標識。

虛擬地址空間:所有可能地址的集合。

字:每臺計算機都有一個字長(word size),指明整數和指針數據的標稱大小(norminal size)。一個字長為n位的機器,虛擬地址的范圍為0~2n-1,程序最多能訪問2n字節。

 

C中的指針,不論其指向什么,都是某個存儲塊的第一個字節的虛擬地址。C編譯器把每個指針和類型信息聯系起來,以根據指針類型,生成不同的機器級代碼來訪問存儲在指針所指向位置的值。C編譯器維護著這個類型信息,但它生成的機器級程序并沒有關于數據類型的信息,它簡單地把每個程序對象視為一個字節塊,而將程序本身看做一個字節序列。

C語言中數字數據類型的大小(單位:字節)

C聲明

典型32位機器

Compad Alpha機器

Char

Short int

Int

Long int

1

2

4

4

1

2

4

8

Char *

4

8

Float

Double

4

8

4

8

 

1.1.1.2.          十六進制

一個字節的值域,用二進制表示為000000002~111111112。十六進制表示為0016~FF16。在C中,以0x或0X開頭的數字被認為是16進制的值。

十進制數字x轉十六進制:【x=q0*16 + r0】->【q0=q1*16 + r1】->……->【rn = 0*16 + r n】,則結果為【rn rn-1… r2 r1】,當然ri要寫成相應的十六進制數字。

1.1.1.3.          尋址和字節順序

對跨越多字節的程序對象,我們必須建立兩個規則:這個對象的地址是什么?我們在存儲器中如何對這些字節排序?

答:1.多字節對象被存儲為連續的字節序列,對象的地址為所使用字節序列中最小的地址。

2.對表示一個對象的字節序列排序有兩種規則,大端法和小端法。大端法:最高有效字節在最前面;小端法:最低有效字在最前面。如有一個十六進制數字0x01234567,其表示如下表所示:

 

大端法

 

0x100

0x101

0x102

0x103

 

01

23

45

67

小端法

0x100

0x101

0x102

0x103

 

67

45

23

01

 

關于字節序在網絡通信時就變得很重要。由于不同的計算機可能出現大端法和小端法的區別,所以在發送某些數據之前需要將數據從主機字節序轉換為網絡字節序,而在收到數據后,又需要將數據從網絡字節序轉換為主機字節序進行處理。

打印程序對象的字節表示:

#ifndef SHOW_BYTE_H
#define SHOW_BYTE_H

#include 
<stdio.h>    
typedef unsigned 
char *byte_pointer; 
class CShowBytes
{
public:
    
void show_bytes(byte_pointer start, int len)         
    
{                                            
        
int i;                                     
        
for(i=0; i<len; i++)                        
        
{                                        
            printf(
" %.2x", start[i]);                 
        }
                                        
        printf(
"\n");                                
    }
                                            

    
void show_int(int x)                             
    
{                                            
        show_bytes((byte_pointer)
&x, sizeof(int));     
    }
                                            

    
void show_float(float x)                         
    
{                                            
        show_bytes((byte_pointer)
&x, sizeof(float));     
    }
                                            

    
void show_pointer(void *x)                         
    
{                                            
        show_bytes((byte_pointer)
&x, sizeof(void *));    
    }
    
    
void show_string(char start[], int len)         
    
{                                            
        
int i;                                     
        
for(i=0; i<len; i++)                        
        
{                                        
            printf(
" %.2x", start[i]);                 
        }
                                        
        printf(
"\n");                                
    }
    
}
;
#endif


1.1.1.4.          字符串

C字符串為以NULL字符結尾的字符數組。為什么前面我提到在網絡通信時,是需要對“某些”數據進行主機字節序和網絡字節序之間的轉換,而不是所有?是因為字符串具有平臺獨立性。為什么呢?

因為每個字符都由標準編碼來表示,常用ASCII編碼,如使用ASCII碼的字符碼在任何系統傷將得到同樣的結果,與字節順序和字大小無關。下圖對比了數字和字符串在內存中的存儲形式,由于一個字符恰好對應一個字節,所以與字節順序沒有關系,而數字的話涉及到位數先后順序的問題就不同了。

1.1.1.5.          布爾代數和環,C的位、邏輯運算

二進制是計算機編碼、存儲和操作信息的核心。而圍繞0和1的布爾運算和環結構就變得異常重要。布爾代數<{0, 1}, |, &, ~, 0, 1>和基本的算術運算有很多相似的特性,如交換性、結合性、同一性等等。紅綠藍三種基本色在{0,1}中取值,并進行不同的布爾運算,就產生出了豐富多彩的顏色。

C的位運算和邏輯運算就充分運用到了布爾代數的知識。記得在網上曾看到一道筆試題,就是交換兩個變量x和y的值,但不要引入第三方的變量,如果布爾代數運用得好的話,可以很容易給出下面的解決方案。

void inplace_swap(int *x, int *y)
{
    
*= *^ *y;
    
*= *^ *y;
    
*= *^ *y;
}


          其實這兒就運用到了 a ^ a = 0 和 a ^ 0 = a 的性質。

     邏輯運算與位運算不同的是,如果第一個參數能確定表達式的結果,就不會對后續參數求值進行運算。如p&&*p++就不會間接引用空指針。具體原因請參看后面C的匯編表示中關于邏輯運算的匯編表示部分。

     C的移位運算,左移比較簡單,直接在右邊的空位補0。而右移就不同了,分為邏輯右移和算術右移兩種,邏輯右移也是直接在左邊的空位補0,而算術右移則在左邊的空位補上最高有效位的拷貝。幾乎所有的編譯器/機器組合都對有符號數使用算術右移。移位運算同樣很重要,乘法在Cpu上的執行要比加減法多很多指令,為了提高效率,通常就可以用移位運算對乘法運算進行優化。


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            日韩一级精品视频在线观看| 久热精品视频在线| 久久婷婷蜜乳一本欲蜜臀| 久久精品国产99| 激情综合色丁香一区二区| 亚洲日本视频| 欧美日韩一级视频| 久久午夜视频| 欧美激情在线有限公司| 翔田千里一区二区| 久久久久国色av免费看影院| 99国产精品久久久| 欧美在线啊v一区| 亚洲午夜影视影院在线观看| 久久高清免费观看| 亚洲午夜精品17c| 卡通动漫国产精品| 久久成人精品一区二区三区| 欧美日韩免费观看一区| 欧美a级一区二区| 国产美女在线精品免费观看| 亚洲国产精品久久久久| 国内自拍视频一区二区三区| 一区二区三区四区五区在线| 黑人一区二区三区四区五区| 亚洲另类在线一区| 国产中文一区| 亚洲福利小视频| 国产一区二区三区av电影 | 久久久久欧美精品| 欧美视频日韩视频| 亚洲综合精品自拍| 亚洲色图综合久久| 亚洲电影免费| 91久久精品久久国产性色也91| 欧美视频在线免费| 久久国产精品一区二区三区四区 | 欧美成人自拍视频| 亚洲女优在线| 美女主播一区| 欧美一区二视频| 欧美日韩国产不卡| 欧美.www| 国产亚洲欧美一区二区三区| 亚洲精品日韩综合观看成人91| 国产拍揄自揄精品视频麻豆| 亚洲国产天堂久久综合网| 国产欧美日韩综合一区在线播放| 亚洲精品激情| 亚洲高清不卡av| 在线免费高清一区二区三区| 老司机久久99久久精品播放免费 | 亚洲精品国偷自产在线99热| 欧美一区二区三区免费观看| 亚洲二区在线| 久久成人免费网| 久久亚洲精品视频| 午夜精品福利视频| 欧美中文在线免费| 久久中文字幕一区| 日韩视频一区二区三区在线播放免费观看| 99国产精品久久久久久久久久| 午夜亚洲一区| 欧美综合第一页| 亚洲人成在线影院| 久久乐国产精品| 国产日产欧产精品推荐色| 老司机午夜精品| 欧美在线观看一二区| 亚洲国产专区校园欧美| 亚洲欧洲精品一区二区精品久久久| 欧美激情免费在线| 欧美高清视频免费观看| 亚洲人成久久| 1000部国产精品成人观看| 亚洲国产精品毛片| 久久精品中文| 亚洲国产成人tv| 亚洲视频视频在线| 久久精品九九| 欧美成人精品1314www| 国产精品人成在线观看免费| 国产一区二区久久久| 一区二区三欧美| 久久精品一区二区| 欧美成黄导航| 久久久五月婷婷| 国产日产欧产精品推荐色 | 亚洲欧美国产精品va在线观看| 亚洲欧美日韩视频一区| 欧美激情中文不卡| 亚洲一区二区综合| 欧美日韩一区二区视频在线观看| 亚洲片在线观看| 亚洲丝袜av一区| 麻豆国产精品va在线观看不卡| 嫩模写真一区二区三区三州| 136国产福利精品导航| 久久亚洲风情| 免费在线观看精品| 亚洲免费视频网站| 欧美激情一二三区| 蜜臀久久99精品久久久画质超高清| 一级日韩一区在线观看| 欧美日韩一区二区国产| 亚洲男人第一av网站| 黄色资源网久久资源365| 欧美中文在线免费| 午夜精品久久久久久久99水蜜桃| 欧美激情综合亚洲一二区| 91久久夜色精品国产九色| 亚洲欧洲日产国码二区| 欧美日韩a区| 欧美自拍偷拍午夜视频| 欧美一级黄色录像| 先锋影音一区二区三区| 在线精品视频在线观看高清| 亚洲高清一区二| 国产精品欧美在线| 小处雏高清一区二区三区| 久久精品国产99精品国产亚洲性色 | 亚洲国产精品一区二区www| 欧美国产日本在线| 亚洲一区二区三区四区中文| 欧美在线一二三| 亚洲欧美日韩电影| 久久精品国产69国产精品亚洲 | 久久久久se| 欧美日韩国产va另类| 麻豆久久精品| 国产主播精品在线| 一区二区成人精品| 亚洲国产精品嫩草影院| 你懂的视频欧美| 伊人久久成人| 欧美韩日视频| 国产欧美日韩另类一区| 亚洲精品国产精品国自产观看| 海角社区69精品视频| 午夜精品久久久久久久白皮肤| 亚洲精品一区二区三区av| 久久精品一本| 西瓜成人精品人成网站| 国产精品成人国产乱一区| 亚洲三级影院| 亚洲影视在线| 国产精品三区www17con| 亚洲自拍偷拍福利| 欧美影院视频| 国产一区视频观看| 鲁大师成人一区二区三区| 免费亚洲视频| 一区二区三区波多野结衣在线观看| 久久精品亚洲精品| 亚洲国产精品ⅴa在线观看| 亚洲综合日韩在线| 狠狠入ady亚洲精品经典电影| 日韩亚洲一区二区| 欧美日韩的一区二区| 亚洲欧美日本国产有色| 99精品国产一区二区青青牛奶| 欧美激情一区二区三区全黄| 亚洲一区二区三区三| 国产日韩欧美一二三区| 欧美激情中文字幕一区二区 | 亚洲最新视频在线播放| 国产精品男gay被猛男狂揉视频| 久久天天躁狠狠躁夜夜av| 国内精品模特av私拍在线观看| 一区二区日韩伦理片| 欧美成人69av| 欧美亚洲视频在线看网址| 免费一级欧美片在线播放| 国产深夜精品| 欧美在线免费观看视频| 亚洲国产导航| 亚洲欧美国产视频| 国产精品99久久久久久人 | 你懂的视频欧美| 亚洲电影免费在线观看| 国语精品中文字幕| 国产精品成人v| 久久成人免费日本黄色| 亚洲综合成人在线| 国产一区二区三区黄| 先锋影院在线亚洲| 久久国产精品一区二区三区| 亚洲激情成人| 欧美日韩高清免费| 免费国产一区二区| 一区二区激情视频| 欧美一区在线看| 亚洲一区亚洲| 一区二区三区在线视频播放| 欧美aaa级| 一区二区精品国产| 亚洲黄色影院| 美女国产一区| 久久国产色av| 精品96久久久久久中文字幕无|