对C++语言本身来说,它并不在乎用户把什么类型的对象作为STL容器的元素,因为模板类型参数在理论上可以为任何类型,比如说STL容器仅支持值语义而不支持引用&语义,这并非因为模板类型参数不能为引用,而是因为如果容器元素为引用类型,就会出现“引用的引用、”,“引用的指针、”等C++语义不支持的语法和语义。
直接以普通指针作为容器的元素时,许多人很容易在这上面犯糊涂,尤其是当元素类型为char*或const char*时,他们总以为容器中存放的是字符串,我们知道,指针就是一个地址值,因此以指针为元素存放的就是一些内存地址,而不是真正的数据,这种容器只负责指针元素本身的内存动态分配和释放,而不会负责指针元素所指对象的内存管理任务,因为那是程序的责任。
如:
Void test()
{ typedef std::vector mystrvector;
mystrVactor strVect; //空容器
str Vect.reserve(10); //预留10个指针空间
for(int i=0;i<10;i++)
{
Char * p=new char[i+1];
::memset(p,’h’,i+1);
*(p+i)=’\0’
strVect.insert(strVect.end().p); //新建指针元素,并用p来初始化
}
……..
For(int j=0;j<10;j++)
{
Delete[]strVect[j]; //用户负责释放存储
}
}//strVect是析构函数只负责释放指针元素的内存
千万不要以为容器的析构函数会为你释放指针元素指向动态对象,要想让容器自动帮你管理内存,就得把char*封装成string类。