• <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>

            為生存而奔跑

               :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              271 Posts :: 0 Stories :: 58 Comments :: 0 Trackbacks

            留言簿(5)

            我參與的團(tuán)隊(duì)

            搜索

            •  

            積分與排名

            • 積分 - 328483
            • 排名 - 74

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            在其它高級(jí)語言里,不管是定義(聲明)還是引用,a[i]a[3]都是一個(gè)整體。在C/C++里,卻是一個(gè)表達(dá)式:a[i]是運(yùn)算符[]連接兩個(gè)實(shí)體ai

            C/C++并沒有數(shù)組,有以下幾條理由。

            理由一:C里沒有數(shù)組形式。

            “數(shù)組”名a本身就是一個(gè)指針,與常規(guī)指針不同的是,它是一個(gè)不能移動(dòng)的所謂常指針。

            如在函數(shù)外有定義:

            float a[3] = {1.0, 2.0, 3.0};

            首先在初始化數(shù)據(jù)段分配一塊能容納三個(gè)float數(shù)的空間,并填入三個(gè)初始值,然后定義一個(gè)名為a指向float數(shù)據(jù)流的常指針,并使其指向該區(qū)域的首字節(jié)。

            理由二:“數(shù)組”的定義,其實(shí)最終是對(duì)指針的定義。

            說“指向float數(shù)據(jù)流”,和說“指向float型數(shù)組”,是兩個(gè)概念。共性是,計(jì)算偏移量(我不說移動(dòng),因?yàn)槌V羔樖遣荒芤苿?dòng)的。)時(shí),計(jì)算單位都是float型數(shù)據(jù)的字節(jié)數(shù)。但是,數(shù)組是有邊界的,你的下標(biāo)不能超出邊界。而偏移量可以超出數(shù)據(jù)流的邊界(后果自負(fù))。

            很多書里說,C“數(shù)組”沒有邊界檢查,是為了運(yùn)行效率。但是,對(duì)邊界的檢查,系統(tǒng)開銷并不大。C里的“數(shù)組”其實(shí)是個(gè)數(shù)據(jù)流,它的邊界只有一頭:常指針?biāo)赶虻南逻吔纭?/span>

            理由三:數(shù)組名和下標(biāo)竟然可以互換。

            我們要訪問上面那個(gè)數(shù)據(jù)流的第2個(gè)數(shù)據(jù),可以使用a[1],也可以使用*(a + 1)。兩者完全等價(jià)。我懷疑,C的作者所提供的a[i],僅僅是*(a + i)的同義詞。按照加法交換率,顯然,*(a + i)等于*(i + a)。那i[a]是不是也等于a[i]呢?測(cè)試結(jié)果:等于。更奇怪的是,不但i[a]等于a[i]1[a]也等于a[1]

            看看下面的相等關(guān)系:

                  a[1] 等于 *(a + 1) 等于 *(1 + a) 等于 1[a]

            上面的懷疑或許有點(diǎn)道理了。

            理由四:a[i]無非是*(a + i)的同義詞。

            對(duì)“數(shù)組”的訪問,最終總是通過指針的。其基本形式是:*(a + i)

            “數(shù)組”名是一個(gè)常指針,總是指向該區(qū)域的首址。“下標(biāo)”其實(shí)是一個(gè)邏輯偏移量。說它是“邏輯”的,意思是在計(jì)算時(shí),需要乘以步長(zhǎng)(數(shù)據(jù)的長(zhǎng)度)。但是,這個(gè)“乘法”對(duì)你是透明的,不必關(guān)心它。指向所訪問數(shù)據(jù)的是常指針“加”偏移量。

            X86系列CPU的指令系統(tǒng)里,有一個(gè)基址變址尋址方式。這種尋址方式和C對(duì)“數(shù)組”的訪問方式很相似。常指針相當(dāng)于基址,偏移量相當(dāng)于變址。

            我懷疑,這個(gè)基址變址尋址方式是為C訪問“數(shù)組”而增加的。

            理由五:C“數(shù)組”沒有上邊界。

            對(duì)下面的定義

            float a[3] = {1.0, 2.0, 3.0};

            我們不僅可以訪問a[0]a[1]a[2],還可以訪問a[3]a[4]等。C數(shù)組不知道自己的一畝三分到哪里為止。用C/C++開發(fā),與用其它語言不同,編程員必須記住自己定義的數(shù)組有多大。自己的家沒有柵欄,跑到鄰居割韭菜沒人管,但后果自負(fù)。

            理由六:對(duì)“多維數(shù)組”的訪問總是可化解成對(duì)“一維數(shù)組”的方式。

            誠(chéng)然,不管是用哪種語言編程,最終生成的目的碼中,數(shù)組總是被轉(zhuǎn)換成一塊連續(xù)的存儲(chǔ)區(qū)(即它是線狀的)。不同的是,在C源碼里,所有的數(shù)組,不管是幾維的,都是線狀的。在源碼層面,都可以看作是一維的。定義了

                  int  a[3][4];

            可以用a[2][3],也可以用a[11]訪問其第2行、第3列元素。

            結(jié)論

            C里使用下標(biāo)運(yùn)算符[],無非是使指向一串等類型元素的指針對(duì)該區(qū)域的操作看起來像操作數(shù)組而已。沒有這東西,習(xí)慣了其它高級(jí)語言數(shù)組操作的編碼員會(huì)覺得不習(xí)慣。

            posted on 2011-01-01 19:12 baby-fly 閱讀(1046) 評(píng)論(12)  編輯 收藏 引用 所屬分類: 無聊

            Feedback

            # re: C/C++沒有數(shù)組 2011-01-17 12:45 asda
            不錯(cuò)  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-17 21:14 sdas
            a[11] 你是做不到的...b[11]或許可以  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-17 21:18 sdas
            (*a)[11]  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-19 11:39 asda
            a[0][11]
            0[a][11]  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-19 11:49 asda
            a[5][4][6][3][7]

            ==

            5[a][4][6][3][7]

            其他組合就不行,第一階的運(yùn)算 *(a+5)=*(5+a)  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-19 13:10 asda
            聲明1個(gè) ***a 代表的是3階等級(jí)的指針
            只要運(yùn)算式中不出現(xiàn)3階消去指針特性的運(yùn)算,就不會(huì)給出地址所指向的值.

            比如 **a ,雖然((a+0)+0)地址上是有值的,但是由于表達(dá)式開始發(fā)覺一個(gè)3階的指針對(duì)象參與了運(yùn)算,所以必須出現(xiàn)3個(gè)* 號(hào)才能將地址的值輸出,否則都是3階地址屬性封裝該指針..  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-19 13:16 asda
            但是..指針對(duì)象 a 是有地址的,也有內(nèi)容,內(nèi)容自然就是指向的對(duì)象的地址  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-19 13:18 asda
            數(shù)組名那個(gè)指針,就只是指著自己 自己的地址 的內(nèi)容 是自己的地址  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-19 13:21 asda
            所有的指針都是結(jié)構(gòu)對(duì)象 有自己的參數(shù)表..
            自己的值
            編譯時(shí)是 指向值的類名

            運(yùn)行時(shí)是 指向值的長(zhǎng)度  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-19 23:28 asda
            數(shù)組名是常量,在編譯后直接變成程序的棧段數(shù)組塊"地址值"所以不是一個(gè)指針對(duì)象

            而僅僅是個(gè)地址值..

            *可以操作地址值

            所以之前的推論有部分就得重新思考
              回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-20 10:38 asda
            后來又考慮了很多.....也是推論了這次

            數(shù)組名是否會(huì)分配空間,取決于你程序中是否需要..或許可以在同一段程序里既出現(xiàn)為數(shù)組名分配空間也出現(xiàn)不為數(shù)組名分配空間的做法..

            分配空間就是,數(shù)組名被引用
            不分配空間就是,數(shù)組名直接編譯為常量  回復(fù)  更多評(píng)論
              

            # re: C/C++沒有數(shù)組 2011-01-20 10:41 asda
            數(shù)組名的指針運(yùn)算可能就會(huì)使數(shù)組被引用..

            這看來取決于編譯器是如何看待 指針運(yùn)算的對(duì)象的..  回復(fù)  更多評(píng)論
              


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久国产高清一区二区三区| 亚洲色婷婷综合久久| 久久综合给久久狠狠97色 | 伊人久久大香线蕉精品不卡| 国产激情久久久久影院老熟女 | 国产69精品久久久久APP下载| 亚洲?V乱码久久精品蜜桃| 无码超乳爆乳中文字幕久久| 18岁日韩内射颜射午夜久久成人| 久久青青草原亚洲av无码| 奇米影视7777久久精品| 久久久久国产日韩精品网站| 久久久久亚洲AV成人片| 久久涩综合| 一本大道加勒比久久综合| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 久久99热这里只有精品国产| 91精品国产高清久久久久久91| 伊人久久大香线蕉综合影院首页 | 99久久99久久精品国产片| 亚洲国产另类久久久精品小说| 久久强奷乱码老熟女网站| 久久91精品国产91久久麻豆| 亚洲va久久久噜噜噜久久狠狠| 久久青青国产| 欧美粉嫩小泬久久久久久久| 日本免费一区二区久久人人澡| 久久久久久九九99精品| 亚洲综合伊人久久大杳蕉| 久久亚洲精品成人无码网站| 婷婷久久综合| 青青热久久国产久精品| 久久婷婷五月综合成人D啪| 丁香五月综合久久激情| 久久九九亚洲精品| 天天久久狠狠色综合| 91久久精品国产成人久久| AA级片免费看视频久久| 国内精品久久久久久久涩爱| 久久精品国产国产精品四凭| 亚洲精品99久久久久中文字幕|