C:获取std :: vector的起始地址?

有时使用std :: vector的起始地址并暂时将该地址视为定期分配的缓冲区的地址是有用的.
例如替换这个:
char* buf = new char[size];
 fillTheBuffer(buf,size);
 useTheBuffer(buf,size);
 delete[] buf;

有了这个:

vector<char> buf(size);
 fillTheBuffer(&buf[0],size);
 useTheBuffer(&buf[0],size);

这样做的好处当然是缓冲区自动解除分配,我不必担心delete [].

我遇到的问题是当size == 0.在这种情况下,第一个版本正常工作.一个空缓冲区被“分配”,后续函数没有任何大小,它们得到size == 0.
然而,如果size == 0,则第二个版本失败,因为调用buf [0]可能正确地包含0 <0的断言.尺寸. 那么即使向量是空的,还有一个替代成语& buf [0],它返回向量的起始地址吗? 我也考虑过使用buf.begin(),但根据标准,它甚至不能保证返回一个指针.

解决方法

我想你只需要检查一下.

可能是效用函数

template <class T,class Alloc>
T* data(std::vector<T,Alloc>& vec)
{
    return vec.empty() ? 0 : &vec[0];
}

template <class T,class Alloc>
const T* data(const std::vector<T,Alloc>& vec)
{
    return vec.empty() ? 0 : &vec[0];
}

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...