您需要匹配 ABI。当您使用 extern "C" 块时,您需要使用相同的 ABI 声明您的函数。
使用平台的约定命名您的动态库。在 macOS 上使用 .dylib,在 Windows 上使用 .lib,在 Linux 上使用 .so。如果您不提供 -o 选项,rustc 会自动为您执行此操作。
构建动态库后,您需要将其添加到编译器的链接器选项中。 rustc --help 有一个各种编译器选项的列表。 -L 将目录添加到搜索路径,-l 链接到特定库。
lib.rs
#[no_mangle]
pub extern "C" fn hello() {
println!("Hello, World!");
}
main.rs
extern "C" {
fn hello();
}
fn main() {
unsafe {
hello();
}
}
编译并执行:
$ rustc --crate-type=cdylib lib.rs
$ rustc main.rs -L . -l lib
$ ./main
Hello, World!
由于我在 macOS 上,我使用 otool 来表明它确实是动态链接的:
$ otool -L main
main:
liblib.dylib (compatibility version 0.0.0, current version 0.0.0)
/usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 1252.250.1)
/usr/lib/libresolv.9.dylib (compatibility version 1.0.0, current version 1.0.0)
另见:
为了完整起见,这里是板条箱的“正常”链接:
lib.rs
pub fn hello() {
println!("Hello, World!");
}
main.rs
fn main() {
lib::hello();
}
$ rustc --crate-type=rlib lib.rs
$ rustc main.rs --extern lib=liblib.rlib
$ ./main
Hello, World!
$ otool -L main
main:
/usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 1252.250.1)
/usr/lib/libresolv.9.dylib (compatibility version 1.0.0, current version 1.0.0)