使用Cargo工具高效创建Rust项目


Posted in Javascript onAugust 14, 2022

前言

本文紧跟上篇Rust博文内容,讲解Cargo工具在Rust项目创建时的妙用,手把手教你使用Cargo工具在黑窗口创建项目。此外,创建项目之后,简单的做一个Rust语言中输入输出的测试,上文提到学好Rust语言的方法就是一步一步打基础,因此仍要潜心修炼,打牢基础。

一、功能强大的Cargo工具

1、Cargo工具是什么?

  • Cargo是Rust 的构建系统和包管理工具,主要功能包括:
    • 创建和管理 Rust 的模块系统
    • 下载和管理依赖库
    • 调用rustc或其他构建工具来构建项目
  • 安装Rust 的时候会自动安装Cargo
    • 验证的命令:cargo --version

2、使用Cargo命令创建 hello_cargo 项目

命令:cargo new hello_cargo

使用Cargo工具高效创建Rust项目

其中code .是VSC工具的命令,意思是使用他来打开项目文件:

使用Cargo工具高效创建Rust项目

可以看到Cargo工具为我们生成了其他的文件,具体看一下都是什么作用:

自动创建了一个新目录hello_cargo,包含:

  • Cargo.toml
  • src目录
    • main.rs
  • 初始化了一个新的Git仓库:.gitignore
    • 可以使用其他的vcs(版本控制系统)
    • 或者不适用vcs:cargo new 项目名 --vcs

3、项目文件目录里各文件的内容和特点

  • Cargo.toml
  • TOML(Tom’s Obvious,Minimal Language)格式,存放Cargo的配置

使用Cargo工具高效创建Rust项目

  • [package],是一个区域标题,表示下方内容是用来配置包的(package)
  • name:项目名
  • version:项目版本
  • edition:使用的Rust版本
  • [dependencies]
  • 另一个区域的开始,它会列出项目的依赖项。
  • 在Rust里,代码的包写做:crate

2.src/main.rs

  • cargo生成的 main.rs 在src目录下,此外源代码都应该放在src目录下
  • 而cargo.toml在项目顶层下
  • 顶层目录可以放置:RENAME、许可信息、配置文件等
  • 将非cargo创建的项目转化为cargo的方法:
  • 把源代码移动到src里面
  • 创建cargo.toml并填写相应的配置

3.Cargo.lock

  • 第一次执行Cargo build命令会在顶层目录生成 cargo.lock文件
  • 该文件负责追踪项目依赖的精确版本
  • 不需要手动修改此文件

4、Cargo 常用命令

  • cargo build
  • 创建可执行文件:target\debug\hello_cargo.exe
  • cargo run
  • 构建和运行cargo项目,编译代码+执行结果
  • 如果之前编译过且源码没有发生改变,则会直接运行二进制文件
  • cargo check
  • 检查代码,确保能够通过编译,但是不产生任何可执行文件
  • cargo check 要比 cargo build 快得多
  • 编写代码得时候可以周期性得使用cargo check命令检查代码,提高效率
  • cargo build --release
  • 一共两种配置:
  • 开发使用 :cargo build
  • 正式发布: cargo build --release
  • 为发布构建,编译时会进行优化
  • 代码运行速度会更快,但是编译时间长
  • 会在target/release 目录下生成可执行文件,而不是 target/debug

二、Rust 语言的输入输出

1、输入输出测试

源码:

use std::io;
fn main() {
    println!("测试输入输出功能");
    println!("从键盘输入一个数字:");

    let mut a=String::new();

    io::stdin().read_line(&mut a).expect("无法读取行");
    
    println!("输出结果为:{}",a);
}

运行效果:

使用Cargo工具高效创建Rust项目

2、具体代码解析

接下来把不熟悉的代码依次解释:

let mut a=String::new();
 

let用来声明变量,mut代表该变量值可修改,String::new()意思是调用String类的实例。

  • 在Rust 中默认变量不可修改,加上mut 才可以被修改
  • new 在Rust 中常用来创建类型实例
  • 这句话的意思就是将一个空白的字符串绑定到可变的字符串变量a上
use std::io;
io::stdin().read_line(&mut a).expect("无法读取行");

use用来引入库,std::io在Rust 中代表标准的输入输出,整体可理解为c中的#include<stdio.h>
在io库调用stdin()类里的read_line()方法,而该方法需要传入可变字符串,因此将 &mut a传入,
为什么要加地址符&呢,这里啊用到了C++里的引用,这样参数列表里字符串的变化会修饰实参a的变化,且不会产生副本,安全高效。最后还有一个ecpect()方法,read_line()方法会返回一个Result枚举类型,含有Ok 和 Err 两个变体。

  • 如果Result返回的是Err,那么expect()方法就会中断整行代码并打印expect里的信息。
  • 如果返回的是OK,那么就会把read_line()方法中得到的值赋给OK一并返回给用户。
println!("输出结果为:{}",a);

类似于c 里的 printf("输出结果为%d",a);上面的{}是一个占位符,输出的时候会被后面变量的值取代,有几个{}后面就有多少变量。

到此这篇关于使用Cargo工具高效创建Rust项目的文章就介绍到这了,更多相关Rust输入输出语句内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
常用参考资料(手册)下载或者链接
Jul 22 Javascript
js控制div及网页相关属性的代码
Dec 19 Javascript
js post方式传递提交的实现代码
May 31 Javascript
jQuery实现的输入框选择时间插件用法实例
Feb 28 Javascript
原生javascript实现自动更新的时间日期
Feb 12 Javascript
关于验证码在IE中不刷新的快速解决方法
Sep 23 Javascript
js模仿微信朋友圈计算时间显示几天/几小时/几分钟/几秒之前
Apr 27 Javascript
bootstrap动态调用select下拉框的实例代码
Aug 09 Javascript
JavaScript中import用法总结
Jan 20 Javascript
微信小程序实现批量倒计时功能
Nov 01 Javascript
推荐几个不错的console调试技巧实现
Dec 20 Javascript
JavaScript享元模式原理与用法实例详解
Mar 09 Javascript
JS实现刷新网页后之前浏览位置保持不变示例详解
Aug 14 #Javascript
vue本地构建热更新卡顿的问题“75 advanced module optimization”完美解决方案
Aug 05 #Vue.js
Vue深入理解插槽slot的使用
Aug 05 #Vue.js
React如何使用axios请求数据并把数据渲染到组件
Aug 05 #Javascript
使用JS前端技术实现静态图片局部流动效果
Aug 05 #Javascript
JavaScript圣杯布局与双飞翼布局实现案例详解
Aug 05 #Javascript
react中useState使用:如何实现在当前表格直接更改数据
Aug 05 #Javascript
You might like
基于PHPExcel的常用方法总结
2013/06/13 PHP
javascript 快速排序函数代码
2012/05/30 Javascript
jQuery实现表头固定效果的实例代码
2013/05/24 Javascript
ExtJS4中使用mixins实现多继承示例
2013/12/03 Javascript
在页面上用action传递参数到后台出现乱码的解决方法
2013/12/31 Javascript
javascript页面加载完执行事件代码
2014/02/11 Javascript
写给小白的JavaScript引擎指南
2015/12/04 Javascript
Angularjs中使用Filters详解
2016/03/11 Javascript
jquery实现简单Tab切换菜单效果
2020/07/17 Javascript
Javascript发送AJAX请求实例代码
2016/08/21 Javascript
预防网页挂马的方法总结
2016/11/03 Javascript
用jquery的attr方法实现图片切换效果
2017/02/05 Javascript
在原生不支持的旧环境中添加兼容的Object.keys实现方法
2017/09/11 Javascript
JS验证输入的是否是数字及保留几位小数问题
2018/05/09 Javascript
Vue通过ref父子组件拿值方法
2018/09/12 Javascript
vue中使用codemirror的实例详解
2018/11/01 Javascript
微信小程序下拉菜单效果的实例代码
2019/05/14 Javascript
使用Webpack提升Vue.js应用程序的4种方法(翻译)
2019/10/09 Javascript
vue-cli3单页构建大型项目方案
2020/04/07 Javascript
token 机制和实现方式
2020/12/15 Javascript
使用python实现接口的方法
2017/07/07 Python
python 对类的成员函数开启线程的方法
2019/01/22 Python
安装Anaconda3及使用Jupyter的方法
2020/10/27 Python
html5使用canvas绘制一张图片
2014/12/15 HTML / CSS
无畏的旅行:Intrepid Travel
2017/12/20 全球购物
DERMAdoctor官网:美国著名皮肤护理品牌
2019/07/06 全球购物
俄罗斯品牌服装在线商店:VIPAVENUE
2020/08/10 全球购物
学生档案自我鉴定
2013/10/07 职场文书
应用化学专业职业生涯规划书
2013/12/31 职场文书
小学新教师培训方案
2014/02/03 职场文书
《小松树和大松树》教学反思
2014/02/20 职场文书
2013年最新自荐信范文
2014/06/23 职场文书
学校学雷锋活动总结
2014/06/26 职场文书
个人融资协议书
2014/10/02 职场文书
素质教育学习心得体会
2016/01/19 职场文书
vue中控制mock在开发环境使用,在生产环境禁用方式
2022/04/06 Vue.js