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

sherrylso

C++博客 首頁 新隨筆 聯系 聚合 管理
  18 Posts :: 0 Stories :: 124 Comments :: 0 Trackbacks

1. 什么是Multi-methods.

在闡述這個概念之前,我們先看一下什么是多態(Polymorphisn)。多態是面向對 象程序設計的一個重要的特征, 多態是允許你將父對象的指針(或者引用)設置成為它的子對象的技術,賦值之后,該父對象指針(或者引用)就可以根據當前賦 值給它的子對象的特性以不同的方式運作。簡單的說,就是一句話:允許將子類類型的指針賦值給父類類型的指針。多態性在C++中都是通過虛函數 (Virtual Function) 實現的。 例如:

class Parent
...
{
    
public:
    
virtual void Test() = 0;
}


class Sub1: public Parent
...
{
public:
   
void Test() 
   ...
{
        cout
<<"HI, this is sub1"<<endl;
   }

}

class Sub2: public Parent
...
{
   
void Test() 
   ...
{
        cout
<<"HI, this is sub2"<<endl;
   }

}


Parent
*  p1 = new Sub1();
Parent
*  p2 = new Sub2();
p1
->Test(); //call the Test method of class Sub1;
p2->Test();//call the Test method of class Sub1;

在c ++中,多態性的內涵是:通過virtual function技術,真實的函數調用完全依賴于對象的真實類型(這就是late binding)。我們的問題是:virtual function調用可不可以依賴于兩個或者兩個以上的對象?這就是multi-methods.

例子:

//method declaration
bool intersect(const Shape&const Shape&,)
...
{
//...
}

bool intersect(const Rectangle&const Circle&,)
...
{
//...
}


class Shape
...
{
//...
}

class Rectangle: public Shape
...
{
//...
}

class Circle: public Shape
...
{
//...
}


Shape
* s1 = new Rectangle();
Shape
* s2 = new Circle();

//while calling the following method, what happend?
//the actual function which will be called is bool intersect(const Shape&, const Shape&,), not bool intersect(const Rectangle&, const Circle&,)
// but what we want is the latter, not former
intersect(*s1,*s2);
//maybe you can call like this, which will meet our requirement, but, unfor?tunately , it violats the principle: we should program based on interface not implementation.
intersect(*(dynamic_cast<Rectangle*>(s1)),*(dynamic_cast<Circle*>(s2)));



2. C++ committee曾經考慮的解決方案(摘自 The Design and Evolution of C++, by Stroustrup)

c++從語言自身來支持multi-method:

//solution 1:
(s1@s2)->intersect();  //rather than intersect(s1,s2);
//solution 2:
bool intersect(virtual const Shape&,virtual const Shape&);
bool intersect(virtual const Rectangle&,virtual const Circle&//overrides
{
}

或許,C++在將來的某個版本會支持multi-method.

3. workarounds for multi-method.

3.1 用double dispatch設計模式解決。

double dispatch(雙分派)設計模式是指:在選擇一個方法的時候,不僅僅要根據消息接收者(receiver)的運行時型別(Run time type,還要根據參數的運行時型別(Run time type。接下來我們用double dispatch來解決一下上面的那個問題:

class Shape
...
{
//...
virtual bool intersect(const Shape&const = 0;
virtual bool intersect(const Rectangle&const = 0;
virtual bool intersect(const Circle&const =0;
}

class Rectangle: public Shape
...
{
//...
bool intersect(const Shape& s) const
...
{
   
return s.intersect(*this); // *this is a Rectangle and calling which intersect method totally depends on the real type of s!
}

bool intersect(const Rectangle&const 
...
{
//...
}

bool intersect(const Circle&const
...
{
//...
}

}

class Circle: public Shape
...
{
//...
bool intersect(const Shape& s) const
...
{
   
return s.intersect(*this); // *this is a Circle and calling which intersect method totally depends on the real type of s!
}

bool intersect(const Rectangle&const 
...
{
//...
}

bool intersect(const Circle&const
...
{
//...
}

}

對于double dispatch, 最大的問題是:這樣的設計與類的繼承結構高度耦合,當類的繼承結構改變后,會影響到現有的代碼。從上面的例子可以看到:Shape 類是不應該意識到它的子類的存在。不過當前的主流面向對象程序設計語言(C++/Java/C#等)都并不支持multi-method, 從這個意義上說:double dispatch還是一個合理,有效地解決方案

3.2 另一個可選的方案是RTTI。

bool intersect(const Shape& s1, const Shape& s2)
{
//the follwing code, can implement by using index table, the key is the type_id of the real object(such as typeid(s1) and typeid(s2))
//the query result is the pointer to function (such as the pointer to function: bool intersect(const Rectangle&, const Circle&).
if( typeid(s1)==typeid(Rectangle) && typeid(s1)==typeid(Rectangle))
{
     intersect(
*(dynamic_cast<Rectangle*>(s1)),*(dynamic_cast<Circle*>(s2)));
}

else if(...)
{
//...
}


}

 
bool intersect(const Rectangle&const Circle&,)
{
//...
}


class Shape
......
{
//...
}

class Rectangle: public Shape
......
{
//...
}

class Circle: public Shape
......
{
//...
}


Shape
* s1 = new Rectangle();
Shape
* s2 = new Circle();
//as a result , for the caller, the code is based on interface not implementation
intersect(*s1,*s2);





posted on 2007-05-06 22:28 愛上龍卷風 閱讀(2245) 評論(4)  編輯 收藏 引用

Feedback

# re: C++與double dispatch設計模式 2009-06-26 18:17 Dan
很好!明白這個東西了。  回復  更多評論
  

# re: C++與double dispatch設計模式[未登錄] 2011-01-08 14:53 darren
個人感覺還是RTTI比較好,代碼比較簡潔一點。  回復  更多評論
  

# re: C++與double dispatch設計模式 2012-02-03 14:52 croma
這樣的意義何在呢?
抽象行為的精神不就是簡化程式碼嗎?

正常的情況下 應該是 Shape 的 class 定義出形狀的描述規則
並且在 Intersect 實做這個規則的計算方法

子類別只要實作出自己的形狀描述就好了

我們不在意執行階段他是什麼型態,只要他完成 Shape 的描述就好了













  回復  更多評論
  

# re: C++與double dispatch設計模式 2013-09-05 01:52 Wangsu

@croma

Shape shapes[]={new Circle(),new Rect(), new Something()...};

foreach(Shape shape in shapes)
{
intersect(shape,next shape);<<=這裡會在 Compiler time 就決定調用 bool intersect(const Shape&, const Shape&,)。
}
  回復  更多評論
  


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            免费亚洲电影在线观看| 久久综合给合久久狠狠狠97色69| 亚洲国产精品一区二区www| 欧美一级久久久| 黄网站免费久久| 欧美aa在线视频| 欧美99久久| 一本色道88久久加勒比精品| 日韩午夜av电影| 国产精品一区=区| 久久精品国产欧美激情| 久久亚洲视频| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 在线亚洲高清视频| 国产精品网红福利| 久久最新视频| 欧美日韩国产不卡| 久久九九久久九九| 欧美大秀在线观看| 欧美一区二粉嫩精品国产一线天| 欧美在线黄色| 一本色道久久综合亚洲二区三区 | 先锋影音网一区二区| 欧美在线二区| 一区二区成人精品| 久久精品久久综合| 亚洲精品一二三| 性欧美暴力猛交69hd| 亚洲国产精品一区二区第四页av| 亚洲精选大片| 永久91嫩草亚洲精品人人| 亚洲美女免费精品视频在线观看| 国产婷婷成人久久av免费高清 | 久久精品一区二区三区不卡| 欧美成人国产一区二区| 久久不见久久见免费视频1| 欧美顶级大胆免费视频| 久久九九免费视频| 欧美日一区二区在线观看 | 欧美亚洲一区二区在线| 欧美91大片| 久久综合成人精品亚洲另类欧美 | 免费久久99精品国产自| 欧美怡红院视频| 欧美日韩专区| 91久久在线视频| 亚洲国产成人精品久久| 午夜性色一区二区三区免费视频| 一区二区三区回区在观看免费视频| 久久成人在线| 久久精品免费看| 国产精品国产三级国产专播品爱网| 亚洲第一级黄色片| 黄色成人av网站| 欧美主播一区二区三区| 午夜精品久久久久久久99热浪潮| 欧美日本韩国一区二区三区| 欧美国产日本| 亚洲国产精品成人综合| 久久在线免费观看视频| 欧美aⅴ一区二区三区视频| 精品51国产黑色丝袜高跟鞋| 午夜免费在线观看精品视频| 亚洲欧美在线一区| 国产精品亚洲网站| 亚洲欧美日韩国产成人精品影院| 午夜精品久久久久久久久久久久| 欧美日韩免费看| 一区二区91| 午夜精品免费在线| 国产日韩免费| 久久国产精品一区二区三区四区| 久久九九久精品国产免费直播| 国产一区二区三区精品久久久| 久久国产主播精品| 欧美h视频在线| 亚洲精品国产视频| 欧美日本久久| 亚洲一二区在线| 久久免费黄色| 亚洲日本中文字幕区| 欧美黄污视频| 亚洲午夜激情网页| 久久久久www| 亚洲国产日韩欧美在线图片| 欧美精品在线免费观看| 99国产精品久久久久久久久久| 亚洲在线视频免费观看| 国产日韩欧美在线播放| 久久综合五月| 中文一区二区| 久久人人看视频| 日韩手机在线导航| 国产精品影片在线观看| 久久中文字幕一区| 中文欧美日韩| 欧美成人免费va影院高清| 在线一区二区日韩| 国产一区二区三区成人欧美日韩在线观看 | 亚洲国产日韩欧美综合久久| 欧美美女操人视频| 先锋亚洲精品| 亚洲人成在线观看| 久久国内精品视频| 日韩午夜免费| 黄色亚洲在线| 国产精品久久久久久久电影| 久久青草欧美一区二区三区| 在线亚洲精品| 亚洲黄色av一区| 久久精品国产视频| 一区二区三区免费网站| 精品电影在线观看| 国产精品成人一区二区网站软件 | 免费成人高清视频| 午夜精品久久99蜜桃的功能介绍| 欧美高清你懂得| 久久精品理论片| 亚洲欧美日韩第一区| 91久久中文| 在线观看91精品国产入口| 国产精品久久久久毛片大屁完整版| 久久免费午夜影院| 欧美一级专区| 亚洲一区二区三区在线播放| 亚洲激情电影在线| 欧美国产高清| 免费欧美日韩| 久久影院午夜论| 久久国产成人| 欧美专区第一页| 午夜精品一区二区三区四区| 亚洲视频免费看| 99国产精品国产精品毛片| 亚洲精品1234| 亚洲第一中文字幕| 在线观看日韩www视频免费| 国产午夜精品在线观看| 国产欧美综合在线| 国产一区二区三区四区| 国产亚洲福利| 韩国av一区二区三区四区| 国产午夜精品美女视频明星a级| 国产精品欧美风情| 国产精品视频不卡| 国产精品女人久久久久久| 国产精品日韩高清| 国产伦精品一区二区三区| 国产伦精品一区二区三区高清版| 国产精品毛片a∨一区二区三区| 欧美三区在线| 国产精品亚洲综合| 国产亚洲电影| 1024成人网色www| 日韩视频一区二区| 在线视频你懂得一区| 亚洲欧美成人一区二区三区| 亚洲欧美中文另类| 久久精品夜色噜噜亚洲a∨ | 亚洲男女自偷自拍图片另类| 亚洲男人的天堂在线观看| 欧美一区二区三区久久精品| 久久精品亚洲一区二区三区浴池| 久久婷婷激情| 亚洲国产裸拍裸体视频在线观看乱了中文 | a4yy欧美一区二区三区| 亚洲一区二区在线免费观看视频| 亚洲欧美日韩在线播放| 久久久噜噜噜久久中文字免| 蘑菇福利视频一区播放| 亚洲人成高清| 亚洲欧美日本在线| 久久亚洲一区二区三区四区| 欧美久久久久久蜜桃| 国产精品美女www爽爽爽视频| 国语自产精品视频在线看| 91久久黄色| 欧美在线资源| 亚洲国产精品高清久久久| 亚洲一区二区三区免费视频| 久久天天躁狠狠躁夜夜爽蜜月| 欧美日韩福利| 一区二区亚洲欧洲国产日韩| 亚洲天堂网在线观看| 久久婷婷av| 亚洲天堂av在线免费| 蜜桃av久久久亚洲精品| 国产精品av久久久久久麻豆网| 激情久久久久久久久久久久久久久久| 亚洲精品字幕| 久热精品视频在线免费观看 | 久久综合电影一区| 99天天综合性| 欧美freesex8一10精品| 国产亚洲成av人在线观看导航| 一区二区三区|亚洲午夜| 久久另类ts人妖一区二区| 亚洲私人影吧| 欧美日韩国产影院| 亚洲欧洲另类国产综合|