一、mod.rs和lib.rs
mod.rs往往是把同一目录下的n个rs文件综合在一起的有效方式;
lib.rs是一个库或子库层次综合在一起的有效方式;
下面举个实例来说明。生成一个rusttoc本地库(由cargo new rusttoc --lib所生成),目录结构如下:
songroom@staff-NB-146:~/myffi/rusttoc/src$ ls -R
.:
bar lib.rs
./bar:
data.rs ffi.rs mod.rs
其中,data.rs文件内容如下:
#[derive(Debug)]
pub struct Tick;
pub trait GetBar{
fn get_bar(&self)->Vec<Bar>;
}
#[derive(Debug)]
pub struct Bar{
open:f64,
close:f64,
min:f64,
max:f64,
}
impl Bar{
pub fn new() ->Self{
Bar { open: 0.0, close: 0.0, min: 0.0, max: 0.0 }
}
}
其中,ffi.rs文件内容如下:
use std::os::raw::{c_int,c_double};
extern "C"{
fn abs(num:c_int) ->c_int;
fn sqrt(x:c_double) ->c_double;
}
#[no_mangle]
pub extern "C" fn rfn_for_c(){
println!("call from rust fn abs :{}",unsafe{abs(-6)});
println!("call from rust fn sqrt :{}",unsafe{sqrt(36.0)});
}
此外,在上面rusttoc库中,在src目录下,除了有lib.rs文件,还有一个bar文件夹,在这个文件夹下,还有3个.rs文件,其中包括一个mod.rs文件。
很显然,mod.rs是把data.rs和ffi.rs综合在一起对外开放的文件。
而lib.rs是在rusttoc这个层次,综合起来的一个对外开放的文件。
当然,如果一个库中,包含若干个子库,那也会存在多个不同层次的lib.rs的文件。
二、use来管理库内容的对外开放
在每层mod.rs和lib.rs文件中,要通过use来约束对外开放的程度和范围。
mod.rs文件
pub mod ffi;
pub mod data;
pub use ffi::rfn_for_c;
pub use data::{Bar,GetBar};//这里设置Tick不暴露
lib.rs文件
pub mod bar;
pub use bar::*;
在mod.rs中,通过pub use来约束ffi.rs和data.rs在此库对外开放(或暴露)的范围,在这里为rfn_for_c函数,以及Bar,以及GetBar。而没有进来的Tick,则表明不对外开放(暴露)。
在lib.rs层次,再次明确对外开放的层次,使用use表统一表明,各个mod.rs或子lib.rs的统一对外开放。
如果没有use安排,以上均会处于关闭状态,均无法以本地库或外地库的方式来调用。当然,在use前,还要声明一下各mod。
三、另外一种方式:include
除了mod.rs,lib.rs之外,还有一种特别的导入形式,即include。它可以把不同形式文件的内容导入到当到的工作空间。
下面,在test文件夹下,放了两个不同后缀的文件。
songroom@staff-NB-146:~/myffi/test$ ls -R
.:
bind.rs const.txt
bind.rs
#[derive(Debug)]
struct Student{
name : String,
age:i32,
}
const.txt
const MIN_VALUE:f64 =30000.0_f64;
四、调用库和include导入
另一个rust 二进制工程文件中,有main.rs如下:
include!("../../test/bind.rs");
include!("../../test/const.txt");
pub use rusttoc::*;
struct Strategy;
//实现本地库中的trait
impl GetBar for Strategy{
fn get_bar(&self)->Vec<Bar>{
vec![Bar::new()]
}
}
fn main() {
let student = Student{name: "wowotuo".to_string(),age:18};
//let tick = Tick;
let bar = Bar::new();
let strategy = Strategy;
println!("bar:{:?}",bar);
println!("strategy ->get_bar:{:?}",strategy.get_bar());//调用trait
//let tick = Tick; //因为mod.rs中没有开放Tick的访问权限,故不能访问
//println!("tick:{:?}",tick);
println!("student :{:?}",student);
rfn_for_c();
println!("const :{:?}",MIN_VALUE);
println!("Hello, world!");
}
另外,在这个工程下,cargo.toml文件应加下如下部分,表明需要导入本地库,并指明相应的路径:
[dependencies.rusttoc]
path = "../rusttoc" #库的位置
这样,就是main.rs中导入了rusttoc库,以及include了两个文件进来了。文章来源:https://www.toymoban.com/news/detail-730529.html
songroom@staff-NB-146:~/myffi/work/src$ cargo run --release
Compiling work v0.1.0 (/home/songroom/myffi/work)
Finished release [optimized] target(s) in 1.68s
Running `/home/songroom/myffi/work/target/release/work`
bar:Bar { open: 0.0, close: 0.0, min: 0.0, max: 0.0 }
strategy ->get_bar:[Bar { open: 0.0, close: 0.0, min: 0.0, max: 0.0 }]
student :Student { name: "wowotuo", age: 18 }
call from rust fn abs :6
call from rust fn sqrt :6
const :30000.0
Hello, world!
上面分别实现本地库中trait,调用了const,相关函数和struct等。文章来源地址https://www.toymoban.com/news/detail-730529.html
到了这里,关于Rust :mod.rs和lib.rs中use的作用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!