reinterpret_cast 向量

vector with 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;
}

我不确定这段代码是如何工作的?

您的代码表现出未定义的行为

std::vector<void*>std::vector<int> 是两个完全独立且不相关的类型,您不能像现在这样安全地在它们之间进行转换,尤其是因为无法保证 void*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;
}

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

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

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

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

    add(col);

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

    return 0;
}