请考虑以下代码:
std::vector<std::string> foo{{"blee"},{"bleck"},{"blah0000000000000000000000000000000000000000000000000000000000000000000000000000000000"}}; std::string *temp = foo.data(); char*** bar = reinterpret_cast<char***>(&temp); for (size_t i = 0; i < foo.size(); ++i){ std::cout << (*bar)[i] << std::endl; }
显然这是粗略的代码,但它恰好起作用.
我想知道它为什么有用吗?有一些奇怪的C规则我不知道吗?或者只是糟糕的代码和未定义的行为?
我做了一个巨大的字符串,以防有一些小字符串优化正在进行.
解决方法
这是非常不确定的行为.
如果字符串实现恰好包含指向字符串数据的指针作为其唯一的数据成员,它将显示为“工作”,因此字符串数组具有与char *数组相同的内存布局.对于至少一个流行的实现(GNU)来说就是这种情况,但肯定不是你可以依赖的东西.