我如何转换一个std::vector<双>到双数组[]?


当前回答

如果你有一个函数,那么你可能需要这样:foo(&array[0], array.size());。如果你遇到了需要数组的情况,那么你需要重构,向量基本上是扩展数组,你应该总是使用它们。

其他回答

对什么?您需要澄清:您需要指向数组或数组的第一个元素的指针吗?

如果你正在调用一个期望前者的API函数,你可以执行do_something(&v[0], v.size()),其中v是一个双精度向量。向量的元素是连续的。

否则,你只需要复制每个元素:

double arr[100];
std::copy(v.begin(), v.end(), arr);

确保不仅arr足够大,而且arr被填满,或者你有未初始化的值。

对于std::vector<int> vec, vec获取int*,可以使用两种方法:

Int * arr = &vec[0]; Int * arr = vvector .data();

如果你想将任何类型的T向量转换为T*数组,只需将上面的int替换为T。

为了更好地理解,我将向你展示为什么上面两个是有效的?

vector本质上是一个动态数组。

主要数据成员如下:

template <class T, class Alloc = allocator<T>>
class vector{
    public:
        typedef T          value_type;
        typedef T*         iterator;
        typedef T*         pointer;
        //.......
    private:
        pointer start_;
        pointer finish_;
        pointer end_of_storage_;

    public:
        vector():start_(0), finish_(0), end_of_storage_(0){}
    //......
}

range (start_, end_of_storage_)是vector所分配的所有数组内存;

range(start_, finish_)是vector使用的所有数组内存;

范围(finish_, end_of_storage_)是备份阵列内存。

比如向量vec。其中有{9,9,1,2,3,4}是指针,可以像下面这样。

因此,&vec[0] = start_ (address.) (start_等价于int*数组头)

在c++11中,data()成员函数只返回start_

pointer data()
{ 
     return start_; //(equivalent to `value_type*`, array head)
}

有一个相当简单的技巧来做到这一点,因为规范现在保证向量连续存储它们的元素:

std::vector<double> v;
double* a = &v[0];

如果你有一个函数,那么你可能需要这样:foo(&array[0], array.size());。如果你遇到了需要数组的情况,那么你需要重构,向量基本上是扩展数组,你应该总是使用它们。

向量实际上是皮肤下的数组。如果你有一个函数:

void f( double a[]);

你可以这样调用它:

vector <double> v;
v.push_back( 1.23 )
f( &v[0] );

你不应该需要将一个向量转换成一个实际的数组实例。