• <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>
            franksunny的個人技術(shù)空間
            獲得人生中的成功需要的專注與堅(jiān)持不懈多過天才與機(jī)會。 ——C.W. Wendte

             

            < 筆記一、數(shù)據(jù)類型 >

            現(xiàn)在業(yè)界普遍認(rèn)可以下等式

            程序 = 數(shù)據(jù)結(jié)構(gòu)   + 算法 + 文檔

            這第一篇筆記就只對以上提到的數(shù)據(jù)結(jié)構(gòu)結(jié)合本人的理解展開做些總結(jié)。

             

            類型

            程序的輸入輸出的實(shí)體就是數(shù)據(jù)信息,而對這些數(shù)據(jù)信息給以歸類和組織,我們就稱為數(shù)據(jù)結(jié)構(gòu)。因此數(shù)據(jù)結(jié)構(gòu)就是對數(shù)據(jù)的組織形式,也可以說是對內(nèi)存的編碼規(guī)則。由于基于底層的數(shù)據(jù)都是二進(jìn)制的 0 1 序列,所以人們通常將 8 個連續(xù)的 0 1 序列看作一個獨(dú)立的結(jié)構(gòu)——字節(jié)( Byte ),字節(jié)中的每一個二進(jìn)制序列就是一個位( bit )。但是這種組織形式太過籠統(tǒng),為此 C 語言提供了四種基本類型(整型、浮點(diǎn)型、字符型、枚舉類型)、三種構(gòu)造類型(數(shù)組、結(jié)構(gòu)體、聯(lián)合體)、指針類型和空類型。 C++ 語言在以上 9 種類型基礎(chǔ)上又增加了一種基本類型—— bool 型和一種構(gòu)造類型——類類型( class )。

             

            編碼規(guī)則

            雖然 C 數(shù)據(jù)類型有 9 C++ 11 種,但是按編碼規(guī)則所有數(shù)據(jù)類型卻只采用了兩種編碼方式,即整型和浮點(diǎn)型。以下對各類型結(jié)合編碼規(guī)則稍作展開:

            整型數(shù)據(jù)根據(jù)有無符號位可以區(qū)分為 signed unsigned 兩種類型,對于 signed 的編碼方式,最高位用做符號位用,其它位用作數(shù)據(jù)位,而 unsigned 類型所有位全都用來做數(shù)據(jù)位。數(shù)據(jù)位采用補(bǔ)碼形式編碼,正數(shù)的補(bǔ)碼以原碼給出,而負(fù)數(shù)的補(bǔ)碼為原碼的反碼加 1 給出,因此 11111111 表示無符號整型時為 255 ,表示有符號整型時為 -1 ANSIC 整型類型給出了三種不同字節(jié)長度類型符為 short int long ,但 ANSIC 并沒有規(guī)定每一種類型的具體長度,可以視不同的編譯器而變化,但要求 short 不長于 int 不長于 long 。通常 32 位用 VC 編譯器編譯時 short 2 字節(jié)、 int 4 字節(jié)、 long 也為 4 字節(jié)。

            浮點(diǎn)型數(shù)據(jù)編碼規(guī)則不區(qū)分有無符號,一致都采用 1 符號位 n 數(shù)據(jù)位 m 指數(shù)位來表示,其中 n 又被稱為浮點(diǎn)類型的有效位數(shù), n 越大則精度越高,同時 m 越大表示的數(shù)據(jù)越大。 ANSIC 給出了不同字節(jié)長度的浮點(diǎn)數(shù)類型 float double ,同樣沒有規(guī)定每一種類型的具體長度,但要求 float 不長于 double 32 VC 編譯下 float 4 字節(jié), double 8 字節(jié)長度。

            字符型,即按 ASCII 碼表排序,以單個字節(jié)長度采用整型編碼方式編碼,也要區(qū)分 signed unsigned 兩種類型。例 char A = 255 unsiged char B = 255, 都是表示同一個字符,但是 A 實(shí)際值為 -1 B 的值才是 255

            枚舉類型,采用 enum 類型符,可以說是一種自定義類型,為了說明 enum 的有用性,我以代碼方式總結(jié):

                const int sun = 0;

                const int mon = 1;

                const int tue     = 2;

                const int wen     = 3;

                const int thu     = 4;

                const int fri     = 5;

                const int sat     = 6;

                int today = sun;

            以上代碼從程序可讀性來說顯然沒有如下采用 enum 方式來的好,至于從代碼執(zhí)行效果來說是否有優(yōu)越性我還不是很清楚,有達(dá)人知道還望指點(diǎn)。

            typedef enum WEEKDAY

                {

                   sun,

                   mon,

                   tue,

                   tue,

                   wen,

                   thu,

                   fri,

                   sat

                }weekDay;

                weekDay today = sun;

            枚舉類型實(shí)際在內(nèi)存中是以 int 類型值編碼的,當(dāng)?shù)谝粋€枚舉類型常量沒有賦初值時,默認(rèn)為 0 開始,以后依次遞增 1

            以上對四種基本類型進(jìn)行了展開,而三種構(gòu)造類型數(shù)組、結(jié)構(gòu)體、聯(lián)合體則是有四種基本類型根據(jù)需求自由組合而成。

            數(shù)組類型,其實(shí)就是根據(jù)需要用戶自定義以同一種類型聲明一個數(shù)組長度的一組變量,數(shù)組類型本身沒有類型符。在內(nèi)存中以同一編碼規(guī)則連續(xù)編碼一塊數(shù)組長度的空間。

            結(jié)構(gòu)類型,則是根據(jù)需求用戶采用不同種類型的數(shù)據(jù)量構(gòu)成的一個新的類型,它以 struct 類型符定義,在內(nèi)存中以事先安排的順序和基本類型編碼規(guī)則編碼。

            聯(lián)合體類型,由于結(jié)構(gòu)類型中的每一中基本類型都是分配一塊內(nèi)存,但是有一種需求是一塊內(nèi)存可以以不同的類型來拆分,這種需求在通信中相當(dāng)常見,為此引進(jìn)了聯(lián)合體類型。見下面列子

            typedef union CODON

               {

                   DWORD m_dwCodon;

                   char  m_chCodon[4];

               }Codon;

            以上定義了常用的四個長度的碼字,每一個碼字都是一個字符,但是為了程序中比較運(yùn)算方便我們可以用一個 DWORD (四個字節(jié)的整數(shù)類型)值來進(jìn)行整數(shù)比較。

             

            指針類型,指針類型本身是一個 32 位即 4 個字節(jié)來描述的正整數(shù)數(shù)據(jù),表示的是變量的內(nèi)存地址,所以不管指針是定義成何種類型用 sizeof 取得的始終是 4 字節(jié)長度,但是指針做增一運(yùn)算時就跟具體的數(shù)據(jù)類型相關(guān)了。如 char *p p++ 就是加 1 ,而 int *p p++ 就是加 4 了。

            空類型,即 void 類型,在函數(shù)返回值和形參中用的比較多,并且與指針類型常結(jié)合在一起用,該類型弱化了編碼規(guī)則,但是不能用這種類型來聲明和定義變量。

            C++ 新增的兩種類型, bool 型其實(shí)也是一個字節(jié)類型的,按照整型數(shù)據(jù)來編碼,其值 true 1 false 0 。至于 class 類型,在內(nèi)存中編碼規(guī)則等同與 struct 。以后將做更多的討論。

             

            至此,將 C C++ 內(nèi)的數(shù)據(jù)類型做了一個小小闡述,下一節(jié)將小結(jié)變量。

             

            posted on 2006-11-10 23:43 frank.sunny 閱讀(785) 評論(0)  編輯 收藏 引用 所屬分類: C/C++學(xué)習(xí)和實(shí)踐

            常用鏈接

            留言簿(13)

            隨筆分類

            個人其它博客

            基礎(chǔ)知識鏈接

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品国产免费| 久久精品免费大片国产大片| 国产一级持黄大片99久久 | 亚洲国产精品无码久久九九| 亚洲欧洲久久av| 成人妇女免费播放久久久| 精品国产婷婷久久久| 亚洲熟妇无码另类久久久| 亚洲国产精品热久久| 99久久精品免费看国产一区二区三区| 99精品久久久久中文字幕| 久久天天婷婷五月俺也去| 久久国产精品成人免费| 伊人久久综合精品无码AV专区| 93精91精品国产综合久久香蕉 | 久久精品国产一区二区三区不卡| 中文字幕热久久久久久久| 国产成人精品综合久久久| 国内精品久久久久影院一蜜桃| 亚洲国产日韩欧美久久| 精品乱码久久久久久夜夜嗨| 国产婷婷成人久久Av免费高清| 久久乐国产综合亚洲精品| 99国内精品久久久久久久| 国内精品久久久久久久97牛牛| 久久精品国产99久久久古代| 亚洲欧美精品一区久久中文字幕| 超级碰久久免费公开视频| 国产99精品久久| 国产精品久久久久久久久免费| 99久久国产宗和精品1上映 | 韩国免费A级毛片久久| 亚洲AV无码1区2区久久| 久久久黄色大片| 欧美激情一区二区久久久| 久久伊人亚洲AV无码网站| 一本大道久久a久久精品综合| 2021久久国自产拍精品| 国产精品久久成人影院| 国产精品久久网| 国产精品久久久天天影视|