• <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>
            隨筆 - 87  文章 - 279  trackbacks - 0
            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            潛心看書研究!

            常用鏈接

            留言簿(19)

            隨筆分類(81)

            文章分類(89)

            相冊

            ACM OJ

            My friends

            搜索

            •  

            積分與排名

            • 積分 - 219046
            • 排名 - 118

            最新評論

            閱讀排行榜

            評論排行榜

            C++指針探討 (-) 數據指針- -

               ------轉載沐楓's blog                                   

                指針,在C/C++語言中一直是很受寵的;幾乎找不到一個不使用指針的C/C++應用。用于存儲數據和程序的地址,這是指針的基本功能。用于指向整型數,用整數指針(int*);指向浮點數用浮點數指針(float*);指向結構,用對應的結構指針(struct xxx *);指向任意地址,用無類型指針(void*)。
                有時候,我們需要一些通用的指針。在C語言當中,(void*) 可以代表一切;但是在C++中,我們還有一些比較特殊的指針,無法用(void*)來表示。事實上,在C++中,想找到一個通用的指針,特別是通用的函數指針可是一個“不可能任務”。
               
                C++是一種強類型的語言,C++的編譯器的功能是強大的,它的其中一個設計目標,是盡力為程序找出程序中可能存在的問題;因此,C++對類型的匹配是非常嚴格的。在C語言中,你可以用void*來指向一切;但在C++中,void*并不能指向一切,就算能,也沒有意義,因為它不能幫你發現問題,比如,用函數指針賦值給一個數據指針。
               
                下面我們來探討一下,C++中如何存儲各種類型的指針。
               
                1.  數據指針
                 數據指針分為兩種:常規數據指針和成員數據指針
                 
                1.1 常規數據指針 (難度: 1)
                 這個不用說明了,和C語言一樣,很簡單,直接定義、賦值就夠了。常見的有:int*, double* 等等。
                 如:
                 int value = 123;
                 int * pn = &value;
                 
                 
                1.2 成員數據指針 (難度: 4)
                 有如下的結構:
                 struct MyStruct
                 {
                   int key;
                   int value;
                 };
                 
                 現在有一個結構對象:
                 MyStruct me;
                 
                 我們需要 value 成員的地址,我們可以:
                 int * pValue = &me.value;
                 
                 :) 沒什么難的對吧?
                 
                 我們假設一下,現在有一個結構的指針:
                 
                 MyStruct* pMe = new MyStruct;
                 現在,我們要取得 pMe中 value 的指針,要怎么做呢?
                 int * ppValue = &pMe->value;
                 
                 :) 這仍然很容易。
                 
                 當然了,上面討論的仍然是屬于第一種范籌----常規數據指針。
                 
                 好了,我們現在需要一種指針,它指向MyStruct中的任一數據成員,那么它應該是這樣的子:
                 int MyStruct::* pMV = &MyStruct::value;
                 或
                 int MyStruct::* pMK = &MyStruct::key;
                 
                 這種指針的用途是用于取得結構成員在結構內的地址。我們可以通過該指針來訪問成員數據:
                 int value = pMe->*pMV; // 取得pMe的value成員數據。
                 int value = me.*pMK; // 取得me的key成員數據。
                 
                 也許有人會問了,這種指針有什么用?
                 確實,成員指針本來就不是一種很常用的指針。不過,在某些時候還是很有用處的。我們先來看看下面的一個函數:
                 
              int sum(MyStruct* objs, int MyStruct::* pm, int count)
              {
                  int result = 0;
                  for(int i = 0; i < count; ++i)
                      result += objs[i].*pm;
                  return result;
              }
                 
                 這個函數的功能是什么,你能看明白嗎?它的功能就是,給定count個MyStruct結構的指針,計算出給定成員數據的總和。有點拗口對吧?看看下面的程序,你也許就明白了:
                 
                 MyStruct me[10] =
                 {
                  {1,2},{3,4},{5,6},{7,8},{9,10},{11,12},{13,14},{15,16},{17,18},{19,20}
                 };
                 
                 int sum_value = sum(me, &MyStruct::value, 10);
                 //計算10個MyStruct結構的value成員的總和: sum_value 值 為 110     (2+4+6+8+...+20)
                 
                 int sum_key = sum(me, &MyStruct::key, 10);
                 //計算10個MyStruct結構的key成員的總和:   sum_key 值 為 100       (1+3+5+7+...+19)
                 
                 
                 也許,你覺得用常規指針也可以做到,而且更易懂。Ok,沒問題:
                 int sum_value(MyStruct* objs, int count)
                 {
                  int result = 0;
                  for(int i = 0; i < count; ++i)
                   result += objs[i].value;
                  return result;
                 }
                 你是想這么做嗎?但這么做,你只能計算value,如果要算key的話,你要多寫一個函數。有多少個成員需要計算的話,你就要寫多少個函數,多麻煩啊。

            posted on 2005-12-26 18:12 閱讀(405) 評論(0)  編輯 收藏 引用 所屬分類: Basic C++
            久久久久噜噜噜亚洲熟女综合| 亚洲国产成人久久综合一区77 | 久久亚洲国产成人精品性色| 囯产极品美女高潮无套久久久| 九九久久自然熟的香蕉图片| 久久精品亚洲男人的天堂| 亚洲日本va中文字幕久久| 一本大道久久a久久精品综合| 一级做a爰片久久毛片看看| 成人久久精品一区二区三区| 性做久久久久久久久浪潮| 高清免费久久午夜精品| 久久综合久久美利坚合众国| 精品熟女少妇av免费久久| 亚洲精品视频久久久| 亚洲国产成人久久综合碰碰动漫3d | 国内精品久久久久久99蜜桃| 久久久久久久国产免费看| 久久精品国产亚洲AV高清热| 精品久久久久久久国产潘金莲 | 精品人妻伦九区久久AAA片69| 久久精品无码专区免费东京热 | 91久久婷婷国产综合精品青草| 亚洲欧洲中文日韩久久AV乱码| 久久精品国产69国产精品亚洲| 99久久国产宗和精品1上映| 亚州日韩精品专区久久久| 国产高潮国产高潮久久久91| 91精品国产综合久久香蕉 | 中文字幕久久精品无码| 久久久久人妻一区二区三区| 美女久久久久久| 久久午夜无码鲁丝片午夜精品| 99热精品久久只有精品| 国产成人精品久久综合| 99久久99久久精品国产| 国产精品美女久久久久av爽| 91精品国产高清久久久久久91| 亚洲一区二区三区日本久久九| 草草久久久无码国产专区| 久久影视综合亚洲|