根据标准,typeid 运算符是依赖于实现的,因此在由不同编译器编译的其他进程创建的对象上使用它是无稽之谈。但是提供进程被同一个编译器编译是什么情况呢?
最佳答案
它可能不会工作,因为外部对象将在它自己的进程空间中包含一个 vtable 指针,而不是检查进程的指针。如果您可以形成一个地址空间,其中两个可执行二进制镜像都在适当的位置,就好像它们正在运行一样,那么也许。如果它是使用相同命令行标志的同一编译器的同一版本,或者如果您的平台 ABI 准确指定了 typeid
在运行时的工作方式,那么您可能没问题。
但严格来说,C++的对象模型并不容纳共享内存。您需要在进程之间传输之前进行序列化,并且无法安全地序列化接收端可能不存在的 C++ 类型。
关于c++ - typeid 是否安全地用于由同一编译器编译的另一个进程提供的指针?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10289269/