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

似乎你也注意到了,不管怎么定義,好像一個鏈表中的對象都是同一類型的。而實際上,這也是必須的,否則,返回節點中的數據這樣的函數的返回值的類型是什么呢?但是,人的要求是無止境的……(省略本人感慨若干百字)。把不同的對象鏈在一個鏈表中的目的是為了方便使用,現在一定記住這個原則,后面的討論都是基于這個原則的,否則,我們就是技術狂人了——偏偏實現一些看起來不可能的事情。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

達到這個目標的原理其實很簡單,只要把不同類型的對象變成同樣的類型就可以了。看下面的結構定義:

struct Mobject

{

       void *p;

       int ObjectType;

};

將一個對象鏈入鏈表時,將指向這個對象的指針賦給p,同時記錄對象類型。當取得這個節點的時候,根據ObjectType的值來確定p指的對象類型,從而還原指針類型,也就得到了原來的對象。

后面講到的廣義表實際上采用的就是這種方法。顯而易見的,這樣的Mobject支持的對象是預先確定的,你將自己維護ObjectType列表,每添加一種類型的支持,你需要在ObjectType列表中給出它的替代值,然后在相應的switch(ObjectType)給出這種類型的case語句。很煩人是吧,下面給出另一種方法,其實還是這個原理,不同的是,把這個煩人的工作交給編譯器了。

還記得前邊強調的原則嗎,為什么我們將不同類型的對象放在一個鏈表中呢?很顯然,我們想達到這樣的一個效果:比如說,我們在一個鏈表中儲存了三角形,直線,圓等圖形的參數,我們希望對某個節點使用Draw()方法,就重繪這個圖形;使用Get()則得到這個圖形的各個參數;使用Put()則修改圖形的參數。可以看出,這些不同的對象實際上有同樣的行為,只是實現的方法不同。

C++的多態性正好可以實現我們的構想。關于這方面,請參閱相關的C++書籍(我看的是《C++編程思想》)。請看如下的例子:

#ifndef Shape_H

#define Shape_H

 

class Shape 

{

public:

       virtual void Input() = 0;

       virtual void Print() = 0;

       Shape(){};

       virtual ~Shape(){};

 

};

 

#endif

【說明】定義一個抽象基類,有兩個行為,Input()為輸入圖形參數,Print()為打印圖形參數。圖省事,只是簡單的說明問題而已。

#ifndef Point_H

#define Point_H

 

class Point 

{

public:

       void Put()

       {

              cout << "x坐標為:";

              cin >> x;

              cout << "y坐標為:";

              cin >> y;

       }

      

       void Get()

       {

              cout << endl << "x坐標為:" << x;

              cout << endl << "y坐標為:" << y;

       }

      

       virtual ~Point(){};

 

private:

       int x;

       int y;

};

 

#endif

【說明】點的類定義與實現。

#ifndef Circle_H

#define Circle_H

 

#include "Shape.h"

#include "Point.h"

 

class Circle : public Shape 

{

public:

       void Input()

       {

              cout << endl << "輸入圓的參數";

              cout << endl << "輸入圓心點的坐標:" << endl;

              center.Put();

              cout << endl << "輸入半徑:";

              cin >> radius;

       }

 

       void Print()

       {

              cout << endl << "圓的參數為";

              cout << endl << "圓心點的坐標:" << endl;

              center.Get();

              cout << endl << "半徑:" << radius;

       }     

       virtual ~Circle(){};

 

private:

       int radius;

       Point center;

};

 

#endif

【說明】圓的類定義與實現。繼承Shape類的行為。

#ifndef Line_H

#define Line_H

 

#include "Shape.h"

#include "Point.h"

 

class Line : public Shape

{

public:

       void Input()

       {

              cout << endl << "輸入直線的參數";

              cout << endl << "輸入端點1的坐標:" << endl;

              point1.Put();

              cout << endl << "輸入端點2的坐標:" << endl;

              point2.Put();

       }

      

       void Print()

       {

              cout << endl << "直線的參數為";

              cout << endl << "端點1的坐標:";

              point1.Get();

              cout << endl << "端點2的坐標:";

              point2.Get();

       }

      

       virtual ~Line(){};

 

private:

       Point point1;

       Point point2;

};

 

#endif

【說明】直線類的定義與實現。繼承Shape的行為。

#ifndef ListTest_H

#define ListTest_H

 

#include <iostream.h>

#include "List.h"

#include "Circle.h"

#include "Line.h"

void ListTest_MObject()

{

       List<Shape*> a;

       Shape *p1 = new Circle;

       Shape *p2 = new Line;

       p1->Input();

       p2->Input();

       a.Insert(p1);

       a.Insert(p2);

       Shape *p = *a.Next();

       p->Print();

       delete p;

       a.Put(NULL);

       p = *a.Next();

       p->Print();

       delete p;

       a.Put(NULL);

}

#endif

【說明】這是測試函數,使用方法是在含有main()cpp文件頭部加入#include “ListTest.h”,然后調用ListTest_Mobject()。這是一個簡單的例子,可以看出,刪除這樣的鏈表節點需要兩個步驟,先delete鏈表節點data域里指針所指的對象,然后才能刪除鏈表節點。同樣,析構這樣鏈表的時候,也需要注意這個問題。不然的話,你的程序運行一次內存就少一點(可能不是這樣,據說操作系統在程序中止時可以回收動態內存,但后面的結論是對的),如果是個頻繁調用的函數,當運行一段時間后,你的系統就癱瘓了。所以,使用這樣的鏈表最好是派生一個新的鏈表類,實現相應的操作。例如這樣:

class ShapeList : public List<Shape*>

{

public:

       BOOL SL_Remove()

       {

              Shape *p = *Get();

              delete p;

              return Remove();

       }

};

【閑話】不知你是不是對這樣的語句Shape *p = *a.Next();       p->Print();不甚理解,還覺得有點羅嗦。那你試試這樣的語句*a.Next()->Print();能不能編譯通過。

Posted on 2005-12-15 12:37 艾凡赫 閱讀(899) 評論(0)  編輯 收藏 引用 所屬分類: C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            99re6这里只有精品| 欧美日韩国产综合视频在线观看中文| 最近中文字幕日韩精品| 999亚洲国产精| 久久免费国产精品| 国产欧美高清| 欧美亚洲免费| 久久精品国内一区二区三区| 亚洲欧美日韩国产综合| 久久在线精品| 欧美国产激情| 亚洲自拍偷拍网址| 欧美**字幕| 国产亚洲福利| 亚洲欧洲久久| 久久久久亚洲综合| 亚洲日本va午夜在线电影| 99av国产精品欲麻豆| 美女网站在线免费欧美精品| 欧美成人午夜免费视在线看片 | 国产亚洲永久域名| 欧美日韩国产综合视频在线观看中文 | 久久亚洲美女| 欧美成人免费在线视频| 国产精品一区视频网站| 日韩亚洲一区二区| 久久噜噜亚洲综合| 亚洲午夜女主播在线直播| 免费精品视频| 黄色av一区| 久久www成人_看片免费不卡| 亚洲人被黑人高潮完整版| 亚洲一区二区三区四区在线观看| 久久久亚洲影院你懂的| 国产三级欧美三级| 久久久国产一区二区| 欧美精品在线极品| 欧美www在线| 在线观看欧美| 久久久精品久久久久| 久久久www成人免费精品| 欧美亚洲三区| 亚洲激情在线观看视频免费| 欧美高清在线观看| 欧美在线三级| 亚洲免费成人av电影| 99热在线精品观看| 有码中文亚洲精品| 日韩视频中文| 黄色成人片子| 亚洲桃花岛网站| 午夜久久影院| 免费在线观看精品| 国产精品jvid在线观看蜜臀| 亚洲大片精品永久免费| 亚洲国产婷婷| 在线亚洲观看| 亚洲日产国产精品| 免费观看亚洲视频大全| 国产伦理一区| 欧美一级黄色网| 亚洲私人影吧| 欧美日韩国产二区| 亚洲精选国产| 亚洲黄色性网站| 男男成人高潮片免费网站| 精品电影在线观看| 欧美77777| 久久亚洲综合色一区二区三区| 国产在线一区二区三区四区| 性欧美办公室18xxxxhd| 香蕉av777xxx色综合一区| 国内精品视频在线播放| 欧美freesex交免费视频| 久久先锋资源| 亚洲美女中文字幕| 亚洲最新中文字幕| 国产精品一区二区三区成人| 欧美制服丝袜第一页| 欧美亚洲综合久久| 在线播放中文一区| 亚洲精品国精品久久99热| 国产精品国产三级国产aⅴ浪潮 | 制服丝袜激情欧洲亚洲| 99亚洲伊人久久精品影院红桃| 国产精品乱码| 老色鬼精品视频在线观看播放| 欧美69视频| 亚洲欧美在线观看| 久久三级福利| 亚洲自拍偷拍一区| 久久亚洲美女| 亚洲综合清纯丝袜自拍| 久久精品视频在线播放| 一区二区三区精密机械公司| 校园春色综合网| 日韩亚洲一区二区| 欧美一区激情| 亚洲一区免费网站| 国产字幕视频一区二区| 黑丝一区二区| 日韩亚洲欧美精品| 国内成+人亚洲| 亚洲精选一区| 一区二区三区亚洲| 亚洲素人在线| 亚洲人在线视频| 亚洲欧美久久久| 亚洲美女毛片| 久久精品91久久久久久再现| 99国产精品私拍| 久久久久女教师免费一区| 亚洲永久免费观看| 欧美成人视屏| 另类欧美日韩国产在线| 国产精品自拍三区| 一道本一区二区| 日韩午夜激情av| 蘑菇福利视频一区播放| 久久夜色精品国产亚洲aⅴ| 国产精品亚洲第一区在线暖暖韩国| 亚洲福利视频在线| 一色屋精品视频免费看| 亚洲欧美国产制服动漫| 午夜精品在线视频| 欧美性做爰毛片| 一个色综合av| 亚洲一区在线免费观看| 欧美日韩在线不卡一区| 亚洲精品综合在线| 99精品免费视频| 欧美精品久久久久久| 亚洲国产精品久久久| 亚洲国产婷婷综合在线精品| 美女日韩欧美| 亚洲国内高清视频| 夜夜嗨网站十八久久| 欧美日韩www| 亚洲精选在线观看| 亚洲在线观看视频| 国产精品一区二区三区久久| 亚洲免费网址| 欧美综合77777色婷婷| 国产老女人精品毛片久久| 午夜一级久久| 鲁大师成人一区二区三区| 精品盗摄一区二区三区| 久久网站免费| 最新国产乱人伦偷精品免费网站| 999在线观看精品免费不卡网站| 欧美高清在线观看| 一区二区三区国产| 久久精品国产亚洲5555| 雨宫琴音一区二区在线| 欧美成人免费一级人片100| 亚洲蜜桃精久久久久久久| 新狼窝色av性久久久久久| 黄色日韩网站| 欧美人与禽性xxxxx杂性| 一区二区三区欧美日韩| 久久女同精品一区二区| 日韩一级在线观看| 国产日韩欧美自拍| 久久躁日日躁aaaaxxxx| 亚洲精品一区在线观看| 亚洲欧美另类在线观看| 国内综合精品午夜久久资源| 欧美紧缚bdsm在线视频| 欧美一区二区久久久| 欧美久久电影| 亚洲欧美大片| 欧美大片免费| 亚洲欧美日韩区| 亚洲国产精品99久久久久久久久| 欧美日韩国产一区精品一区| 午夜精品一区二区三区在线| 亚洲成色精品| 欧美专区18| 99精品黄色片免费大全| 韩国av一区二区三区| 欧美三级视频在线播放| 久久久久久尹人网香蕉| 亚洲视频一区二区| 欧美大片在线观看一区| 久久精品国产精品亚洲精品| 夜夜嗨av一区二区三区网页| 精品91在线| 国产手机视频一区二区| 欧美日本不卡视频| 久久躁狠狠躁夜夜爽| 欧美一级视频精品观看| 在线亚洲欧美视频| 亚洲人成小说网站色在线| 免费不卡视频| 久久精品国产一区二区三| 亚洲在线播放| 亚洲午夜精品17c| 日韩小视频在线观看| 最新国产精品拍自在线播放| 影音先锋中文字幕一区|