矢量与reinterpret_cast

时间:2019-03-13 19:38:06

标签: c++ vector reinterpret-cast

以下代码仅将一个值插入向量col中。 该代码是从DBMS代码库(用于导入文件)中提取的,具体地说,是从1

中提取的

代码使用void *来读取任何字段类型(int,float等)。

#include <iostream>
#include <vector>
using namespace std;

void add(std::vector<void*> &col){
  reinterpret_cast<std::vector<int>&>(col).push_back( 1);
  reinterpret_cast<std::vector<int>&>(col).push_back( 2);
  reinterpret_cast<std::vector<int>&>(col).push_back( 13);
}
int main() {
 std::vector<void*> col;

 add(col);
 cout << col.size() << endl;
 for(int i=0;i<col.size();i++)
    cout <<reinterpret_cast<std::vector<int>&> (col)[i] <<endl;
    return 0;
}

我不确定此代码如何工作?

1 个答案:

答案 0 :(得分:6)

您的代码显示未定义的行为

std::vector<void*>std::vector<int>是两个完全独立且不相关的类型,您不能以自己的方式安全地在它们之间进行强制转换,尤其是因为不能保证void*和{{ 1}}的字节大小相同。

投射您要推送的,请勿投射int本身,例如:

vector

当然,您确实应该使用正确的容器类型开头:

#include <iostream>
#include <vector>
#include <cstdint>
using namespace std;

void add(std::vector<void*> &col) {
    col.push_back(reinterpret_cast<void*>(static_cast<intptr_t>(1)));
    col.push_back(reinterpret_cast<void*>(static_cast<intptr_t>(2)));
    col.push_back(reinterpret_cast<void*>(static_cast<intptr_t>(13)));
}

int main() {
    std::vector<void*> col;

    add(col);

    cout << col.size() << endl;
    for(int i=0;i<col.size();i++)
        cout << reinterpret_cast<intptr_t>(col[i]) << endl;

    return 0;
}