Rust引用借用测试

rust字面量字符串实现了copy trait;

String是引用类型,可使用clone创建新的对象;

Cell可修改copy trait对象;refcell可修改引用对象;

引用/借用对象有生命周期,超过生命周期自动归还引用/借用;

rust 复制代码
use std::cell::Cell;
use std::cell::RefCell;
use std::rc::Rc;
use std::sync::{Arc, Mutex};
use std::thread;

fn main() {
    let s1 = String::from("hello02");
	let s2 = format!("s2={}", s1);
	let s3 = s2.clone();
	let s4 = &s2;
    println!("Hello, world! {}", s1);
	println!("hell every one!{}", s2);
	println!("S3={}",s3);
	println!("&s2={}", s4);
	
	let cell_str = Cell::new("cellTest");
	println!("Initial value:{}", cell_str.get());
	cell_str.set("cellTest01");
	println!("Initial value:{}", cell_str.get());
	
	let str_value01 = "hello".to_owned();
	println!("str_value01={}", str_value01);
	test_str_fun(&str_value01);
	println!("str_value01={}", str_value01);
	
	let cell_string = RefCell::new("001".to_owned());
	{
	    cell_change_test02(&cell_string);
	    let text02 = cell_string.borrow();
	    println!("cell_string02={}", *text02);
	}
	cell_change_test03(&cell_string);
	let text03 = cell_string.borrow();
	println!("cell_string03={}", *text03);
	//RC测试 引用计数
	let vec = vec![1,2,3];
	let rc_data = Rc::new(vec);
	let rc_data1 = rc_data.clone();
    rc_data_test1(rc_data1);
	let rc_data2 = rc_data.clone();
	rc_data_test2(rc_data2);
	//RC+RefCell 引用计数+可修改
	let vec = vec![1,2,3];
    let rc_refcell_data = Rc::new(RefCell::new(vec));
	{
	    //独立开辟一个生命周期范围,让vec借用提前结束,方便后续代码继续使用vec对象
	    let mut vec03 = rc_refcell_data.borrow_mut();
	    vec03.push(4);
	}
	println!("{:?}", rc_refcell_data.borrow());
	
	//Arc测试 多线程只读
	let s = Arc::new(String::from("多线程测试"));
	for _ in 0..10 {
	    let si = Arc::clone(&s);
		let _handle = thread::spawn(move ||{
		    println!("{}", si);
		});
	}
	//多线程可变修改
	let counter = Arc::new(Mutex::new(0));
	let mut thread_list = vec![];
	for _ in 0..10{
	    let count_clone = Arc::clone(&counter);
		let handle_i = thread::spawn(move || {
		    let mut num = count_clone.lock().unwrap();
			*num += 1;
		});
		thread_list.push(handle_i);
	}
	
	for handle in thread_list{
	    handle.join().unwrap();
	}
	println!("Final count: {}", *counter.lock().unwrap());
}

fn rc_data_test1(data: Rc<Vec<i32>>){
	println!("data:{:?}", data);
}

fn rc_data_test2(data: Rc<Vec<i32>>){
    println!("data:{:?}", data);
}

fn test_str_fun(str: &String){
    println!("fun {}", str);
}

fn cell_change_test02(cell:&RefCell<String>){
    let mut text = cell.borrow_mut();
    *text = "002".to_owned();
}

fn cell_change_test03(cell:&RefCell<String>){
    let mut text = cell.borrow_mut();
    *text = "003".to_owned();
}
相关推荐
devmoon2 小时前
从 0 到 1 实现两条独立区块链Parachain的跨链通信能力之实操指南
开发语言·rust·区块链·信息与通信·polkadot
devmoon3 小时前
区块链 Indexer 全解析:为什么 Web3 应用离不开数据索引器?(Polkadot / Ethereum / Solana 对比与未来展望)
rust·web3·区块链·以太坊·polkadot·solana·indexer
@PHARAOH3 小时前
WHAT - SWC Rust-based platform for the Web
开发语言·前端·rust
大鹏的NLP博客5 小时前
Rust + PyTorch 实现 BGE 向量检索系统
人工智能·pytorch·rust
无名之逆1 天前
你可能不需要WebSocket-服务器发送事件的简单力量
java·开发语言·前端·后端·计算机·rust·编程
Source.Liu1 天前
【egui】界面的坐标系统:f32 一统江湖
rust·egui
班公湖里洗过脚1 天前
Rust解析mp3文件及工作目录下多个项目维护示例
rust
sunny_2 天前
构建工具的第三次革命:从 Rollup 到 Rust Bundler,我是如何设计 robuild 的
前端·rust·前端工程化
用户0235087373122 天前
第02篇:5分钟上手 blockcell —— 从安装到第一次对话
rust