我的问题很简单:std :: vector元素是否保证是连续的?在order word中,我可以使用指向std :: vector的第一个元素的指针作为C数组吗?
如果我的记忆力很好,那么C++标准就没有这样的保证.但是,如果元素不连续,那么std :: vector要求几乎不可能满足它们.
有人可以澄清一下吗?
例:
std::vector<int> values;
// ... fill up values
if( !values.empty() )
{
int *array = &values[0];
for( int i = 0; i < values.size(); ++i )
{
int v = array[i];
// do something with 'v'
}
}
Run Code Online (Sandbox Code Playgroud) 目前,我只能使用以下方法进行基于范围的循环:
for (auto& value : values)
Run Code Online (Sandbox Code Playgroud)
但有时我需要一个值的迭代器,而不是一个引用(无论出于何种原因).是否有任何方法无需通过整个矢量比较值?
假设我有以下代码:
vector<int> list;
for(auto& elem:list) {
int i = elem;
}
Run Code Online (Sandbox Code Playgroud)
我可以在elem不保持单独迭代器的情况下找到向量中的位置吗?