练习12.1:
b1包含4个元素,b2也包含4个元素,b1和b2共享一个StrBlob对象
练习12.2:
#include <iostream>
#include <memory>
#include <vector>
using namespace std;
class StrBlob {
public:
typedef std::vector<std::string>::size_type size_type;
StrBlob();
StrBlob(std::initializer_list<std::string>il);
size_type size()const { return data->size(); }
bool empty()const { return data->empty(); }
void push_back(const std::string& t) { data->push_back(t); }
void pop_back();
std::string& front()const;
std::string& back()const;
private:
std::shared_ptr<std::vector<std::string>>data;
void check(size_type i, const std::string& msg)const;
};
StrBlob::StrBlob():data(make_shared<vector<string>>()){ }
StrBlob::StrBlob(initializer_list<string>il):data(make_shared<vector<string>>(il)){ }
void StrBlob::check(size_type i, const string& msg)const
{
if (i >= data->size())
{
throw out_of_range(msg);
}
}
string& StrBlob::front()const
{
check(0, "front on empty StrBlob");
return data->front();
}
string& StrBlob::back()const
{
check(0, "back on empty StrBlob");
return data->back();
}
void StrBlob::pop_back()
{
check(0, "pop_back on empty StrBlob");
data->pop_back();
}
int main()
{
system("pause");
return 0;
}
练习12.3:
不需要,push_back和pop_back会增加或者减小StrBlob共享的vector,即StrBlob的数据成员所指向的内容会发生改变,所以不能用const
练习12.4:
i 是 size_type类型的,是vector<string>::size_type的别名,是unsigned类型的数据,大于等于0
练习12.5:
定义explicit显式构造函数使得构造更加清晰,防止一些我们不希望看到的隐式转换发生。缺点是程序不那么灵活了,无法发生隐式转换