我有一个插件系统,我在其中传递&dyn Any
给动态加载的 rust 函数,但向下转换引用失败,因为TypeId
s 不同(对于相同类型),尽管我添加rustflags = ["-Cmetadata=12345678"]
到两个 crate 的货物配置中。此外,似乎只有来自外部板条箱的类型受到影响(我尝试过()
,它在两个板条箱中都产生了相同的结果TypeId
)。我目前正在使用原始指针 ( unsafe { &*(v as *const dyn Any as *const Type) }
) 来解决这个问题,但我更喜欢没有不安全代码的解决方案。
例如下面的代码:
println!("CRATE 1: TypeId of `()`: `{:?}`, TypeId of `toml::Value`: `{:?}`",
TypeId::of::<()>(), TypeId::of::<toml::Value>());
产生这个输出:
CRATE 1: TypeId of `()`: `TypeId { t: 7549865886324542212 }`, TypeId of `toml::Value`: `TypeId { t: 9270396907601429078 }`
CRATE 2: TypeId of `()`: `TypeId { t: 7549865886324542212 }`, TypeId of `toml::Value`: `TypeId { t: 5704635987193303200 }`
编辑:这似乎不是不同依赖版本的问题,因为板条箱 2(它是动态加载的)取决于板条箱 3(它也是动态加载的)并且问题仍然存在,尽管板条箱 2 和板条箱 3,是本地依赖项(因此只有一个版本)。板条箱 1 是顺便说一句。装载板条箱 2 和 3 的板条箱。
编辑:我-Cmetadata
从所有 3 个 crate 中删除了该选项,现在我得到了相同TypeId
的toml::Value
,但是TypeId
我想在 crate 2 中向下转换的 crate 1 中的类型仍然不同。