1.Builder模式解决的场景
- 将一个复杂对象构建和它的表示相分离,使得同样的构造过程可以创建出不同的对象。
- 对象构建是指得到一个类对象
- 它的表示我的理解就是
初始化
类对象的数据成员
2.Builder模式
2.1流式接口的builder
Builder 模式并非必须得要采用流式接口,但是这是一种典型的实现方法。对于 Builder 模式来说,一个重要的标志,尽管这并不是规定但却往往约定俗成,就是以一个 .build() 调用作为结束。
下面给一个例子,通过给 email 类的四个数据成员 from、to、subject、body 的分步构造来展示 builder pattern 的典型实现方法。
#if 1
#include<iostream>
#include<string>
using namespace std;
class Email
{
friend class Email_Builder;
private:
string from, to, subject, body;
Email(){
};
public:
void print()
{
cout << " from:" <<from<< endl
<< " to:" << to << endl
<< "Subject:" << subject << endl
<<" Body:"<<body<<endl;
}
};
class Email_Builder
{
private:
Email* email;
public:
Email_Builder(){
email = new Email(); }
Email_Builder& setFrom(string _from)
{
email->from = _from;
return *this;
}
Email_Builder& setTo(string _to)
{
email->to = _to;
return *this;
}
Email_Builder& setSubject(string _subject)
{
email->subject = _subject;
return *this;
}
Email_Builder& setBody(string _body)
{
email->body = _body;
return *this;
}
Email* build(void){
return email; }
};
int main()
{
Email_Builder e_builder;
//链式初始化
Email* email = e_builder
.setFrom("me@mail.com")
.setTo("you@mail.com")
.setSubject("About Design Patterns")
.setBody("There is a plan to write a book about cxx17 design patterns. It's good?")
.build();
email->print();
delete email;
system("pause");
return 0;
}
#endif
- 由于 Email_Builder