某图书管理系统中管理着两种类型的文献:图书和论文。现在要求统计所有馆藏文献的总页码(假设图书馆中有一本540页的图书和两篇各25页的论文,那么馆藏文献的总页码就是590页)。采用Visitor(访问者)模式实现该要求,得到如图5-1所示的类图。

图5-1 Visitor模式类图
【C++代码】
class LibraryVisitor;
class LibraryItemInterface{
public:
(1);
};
class Article:public LibraryItemInterface{
private:
string?m_title;//论文名
string?m_author;//论文作者
int m_start_page;
int m_end_page;
public:
Article(string p_author,string p_title,int p_start_page,int p_end_page);
int getNumberOfPages( );
void accept(Library Visitor*visitor);
};
class Book:public LibraryItemInterface{
private:
string?m_title;//书名
string?m_author;//作者
int m_pages;//页数
public:
Book(string p_author,string p_title,int p_pages);
int getNumberOfPages( );
void accept(LibraryVisitor*visitor);
};
class LibraryVisitor{
public:
(2);
(3);
virtual void printSum( )=0;
};
class LibrarySumPrintVisitor:public LibraryVisitor{//打印总页数
private:
int sum;
public:
LibrarySumPrintVisitor( );
void visit(Book*p_book);
void visit(Article*p_article);
void printSum( );
};
//visitor.cpp
int Article::getNumberOfPages( ){
retum m_end_page-m_start_page;
}
void Article::accept(LibraryVisitor*visitor){(4);}
Book::Book(string p_author,string p_title,int p_pages){
m_title=p_title;
m_author=p_author;
m_pages=p_pages;
}
int Book::getNumberOfPages( ){return m_pages;}
void Book::accept(LibraryVisitor*visitor){(5);}
//其余代码省略
正确答案及解析
正确答案
解析
(1)virtual void accept(LibraryVisitor*visitor)=0
(2)virtual void visit(Book*p_book)=0
(3)virtual void visit(Article*p_article)=0
(4)visitor->visit(this)
(5)visitor->visit(this)
本题考查Visitor(访问者)模式的基本概念和应用。
访问者模式是行为设计模式中的一种。行为模式不仅描述对象或类的模式,还描述它们之间的通信模式。这些模式刻画了在运行时难以跟踪的复杂的控制流。访问者模式表示一个作用于某对象结构中的各元素的操作。它使在不改变各元素的类的前提下可以定义作用于这些元素的新操作。此模式的结构图如下图所示。

?Visitor(访问者)为该对象结构中ConcreteElement的每一个类声明一个Visit操作。该操作的名字和特征标识了发送Visit请求给该访问者的哪个类。这使得访问者可以确定正被访问元素的具体的类。这样访问者就可以通过该元素的特定接口直接访问它。
?ConcreteVisitor(具体访问者)实现每个有Visitor声明的操作,每个操作实现本算法的一部分,而该算法片段乃是对应于结构中对象的类。ConcreteVisitor为该算法提供了上下文并存储它的局部状态。这一状态常常在遍历该结构的过程中累积结果。
?Element(元素)定义以一个访问者为参数的Accept操作。
?ConcreteElement(具体元素)实现以一个访问者为参数的Accept操作。
?ObjectStructure(对象结构〉能枚举它的元素;可以提供一个高层的接口以允许该访问者访问它的元素;可以是一个组合或者一个集合,如一个列表或一个无序集合。
本题中类Library对应着上图中的Client,LibraryVisitor对应着Visitor,LibrarySumPrintVisitor对应着ConcreteVisitor。LibraryItemInterface对应着上图中的元素部分。下面可以结合程序代码来完成程序填空了。
(1)空中,LibraryItemInterface在本题中充当着Element的作用,其中应定义以一个访问者为参数的Accept操作。对照实现该接口的两个子类Article和Book的代码,可以得知该操作的原型是void accept(LibraryVisitor visitor)。由此可以得知,此处应该定义的是accept操作,此处填写virtual void accept(LibraryVisitor*visitor)=0。
(2)和(3)空与类LibraryVisitor有关。由前文分析已知,LibraryVisitor对应着访问者模式中的Visitor,其作用是为类LibrarySumPrintVisitor声明Visit操作。类LibrarySumPrintVisitor需要访问两种不同的元素,每种元素应该对应不同的visit操作。再结合类LibrarySumPrintVisitor的定义部分,可以得知(2)和(3)处应给出分别以Book和Article为参数的visit方法。因此(2)和(3)处分别为virtual void visit(Book*p_book)=0、virtual void visit(Article*p_article)=0。
(4)和(5)处考查的是accept接口的实现。由访问者模式的结构图可以看出,在Book和Article中accept方法的实现均为visitor->visit(this)。
包含此试题的试卷
你可能感兴趣的试题
某软件公司项目A的利润分析如下表所示。设贴现率为10%,第二年的利润净现值是 ( ) 元。

-
- A.1,378,190
- B.949,167
- C.941,322D 922,590
- 查看答案
以下关于项目管理计划编制的理解中,正确的是( ) 。
-
- A.项目经理应组织并主要参与项目管理计划的编制,但不应独立编制
- B.项目管理计划的编制不能采用迭代的方法
- C.让项目干系人参与项目计划的编制,增加了沟通成本,应尽量避免D 项目管理计划不能是概括的,必须是详细、具体的
- 查看答案
某软件企业2004年初计划投资1000万人民币开发一套中间件产品,预计从2005年开始,年实现产品销售收入1500万元,年市场销售成本1000万元。该产品的系统分析员张工根据财务总监提供的贴现率,制作了如下的产品销售现金流量表。根据表中的数据,该产品的动态投资回收期是 ( ) 年。

-
- A.1
- B.2
- C.2.27D 2.73
- 查看答案
软件设计过程中,视图可以从不同角度描述软件结构,以下关于几个常见视图的说法中, ( ) 是错误的。
-
- A.逻辑视图从功能需求角度描述了软件结构
- B.组件视图从实现角度描述了软件结构
- C.过程视图从质量角度描述了软件结构D 部署视图从分布问题角度描述了软件结构
- 查看答案
A project manager believes that modifying the scope of the project may provide added value service for the customer. The project manager should ( ) .
-
- A.assign change tasks to project members
- B.call A meeting of the configuration control board
- C.change the scope baseline
- D.postpone the modification until A separate enhancement project is fundeD after this project is completeD according to the original baseline
- 查看答案