美文网首页
Javaer学rust(五)

Javaer学rust(五)

作者: yiang飞扬 | 来源:发表于2022-10-17 18:14 被阅读0次

在前面,我们使用多线程的时候,因为所有权的原因,我们把相关变量都通过clone复制了一遍,这肯定不是好办法,经过查找,发现rust提供了一个Arc智能指针的东西,可以使资源被多个所有者共享。先看代码

fn main() {
    let file_path="D:/uploadBigTest.txt";
    let mut file=std::fs::File::open(file_path).unwrap();
    let file_size=file.metadata().unwrap().len();

    let mut buf=Vec::new();
    file.read_to_end(&mut buf);

    let part_size=10*1024*1024;
    let part_num=if file_size%part_size==0{
        file_size/part_size
    }else{
        file_size/part_size+1
    };
    let client=Arc::new(reqwest::blocking::Client::new());
    let response=client.post("http://localhost:8234/group2/big/upload/")
        .header("Upload-Length",file_size)
        .header("Tus-Resumable","1.0.0")
        .send()
        .unwrap();
    let mut file_location=Arc::new(response.headers().get("Location").unwrap().to_str().unwrap().to_string());

    for i in 0..part_num {
        let start= (i * part_size) as usize;
        let mut end=((i+1)*part_size) as usize;
        if end>(file_size as usize){
            end=file_size as usize;
        }

        let upload_url=file_location.clone();
        let body=(&buf[start..end]).to_vec();
        let http_client=client.clone();
        thread::spawn(move ||{
            let response=http_client.patch(upload_url.as_str())
                .header("Content-Type","application/offset+octet-stream")
                .header("Tus-Resumable","1.0.0")
                .header("Upload-Offset",start)
                .body(body).send().unwrap();
            println!("part {} upload success",i);
        }).join();
    }
}

和之前的代码对比的话,会发现file_location和client两个变量都变成了Arc,使用方式如下:

 let client=Arc::new(reqwest::blocking::Client::new());

但仔细观察的话,在循环体里面,我们还是对client和file_location两个变量执行了clone方法,但此clone非彼clone,arc执行clone,只是对计数器进行了+1的操作,相当于多了一个引用,并没有对堆上的值进行深度复制,类似于java的回收机制,当还有引用的时候就不进行回收了,只不过rust是在编译器进行处理的。我们通过下面代码验证下:

 let arc_test=Arc::new(Mutex::new(vec![]));
  for i in 0..5{
        let arc_clone=arc_test.clone();
        thread::spawn(move||arc_clone.lock().unwrap().push(i)).join();
    }
    println!("{:?}",arc_test);

我们看执行会发现arc_test里面已经包含了0、1、2、3、4五个元素,说明arc_clone和arc_test其实是同一个对象,所以可以证明,arc的clone方法只是对资源的引用。
另外,上面代码还用到了Mutex这个东西,他是rust互斥锁的实现,类似于java的synchronized 和ReentrantLock

上面都是针对多线程来讲的,rust还提供了一个RC的指针,是在单线程下使用的,使用方法和Arc类似,就不再详细写了。

相关文章

  • Javaer学rust(五)

    在前面,我们使用多线程的时候,因为所有权的原因,我们把相关变量都通过clone复制了一遍,这肯定不是好办法,经过查...

  • javaer学rust(四)

    之前实现了文件上传下载的功能,这次我们利用go-fastdfs实现一个分片上传的功能,按照惯例,先贴代码 这段代码...

  • Javaer学rust(七)

    前面我们实现了一个简陋的线程池,其中线程worker会轮询去线程池的队列里面获取要执行的线程,有就执行,没有就不执...

  • Javaer学rust(六)

    前面我们通过多线程完成了文件分片上传,但如果分片多了,会创建比较多的线程,线程多了切换就会带来比较大的开销,下面我...

  • javaer学rust(八)

    文件上传下载先暂告一段落,接下来我们来开发授权服务。我们选用actix-web框架进行开发,其它的框架还有rock...

  • javaer学rust(一)

    最近研究了下rust,看了些相关资料,很多地方还是半知半解,想着写个demo练练手,正好手头在弄一个文件服务器,便...

  • javaer学rust(二)

    按照之前的规划,我们先实现一个下载文件的功能,在此之前我们先部署一个go-fastdfs服务,go-fastdfs...

  • javaer学rust(三)

    在上一篇,我们写了一个只有main方法的demo,实现了下载网络文件的功能,但基于代码复用的思想,我们可以把下载的...

  • RUST学习资源

    《通过例子学 Rust》 《Rust by Example》 《Rust 程序设计语言(第一版)》 《Rust 程...

  • Rust从安装到语法基础

    rust学习资源 rust中文网[https://www.rust-lang.org/zh-CN/]通过例子学ru...

网友评论

      本文标题:Javaer学rust(五)

      本文链接:https://www.haomeiwen.com/subject/nhjdzrtx.html