阶段四:实战(项目开发能力)

目标

将 Rust 应用到真实项目中,掌握生态与工具链,能独立开发 CLI、Web 和网络应用。


1. CLI 工具

使用 clap / structopt

rust 复制代码
use clap::Parser;

#[derive(Parser)]
struct Args {
    #[clap(short, long)]
    name: String,

    #[clap(short, long, default_value_t = 1)]
    count: u32,
}

fn main() {
    let args = Args::parse();
    for _ in 0..args.count {
        println!("Hello, {}!", args.name);
    }
}
  • cargo build --release 打包为二进制文件
  • 文件操作:
rust 复制代码
use std::fs::File;
use std::io::Write;

let mut file = File::create("output.txt").expect("创建文件失败");
file.write_all(b"Hello, Rust CLI!").expect("写入失败");

2. Web 开发

使用 Actix-web 创建 REST API

rust 复制代码
use actix_web::{get, post, web, App, HttpServer, Responder};

#[get("/")]
async fn hello() -> impl Responder {
    "Hello, world!"
}

#[post("/echo")]
async fn echo(msg: String) -> impl Responder {
    msg
}

#[actix_web::main]
async fn main() -> std::io::Result<()> {
    HttpServer::new(|| App::new().service(hello).service(echo))
        .bind("127.0.0.1:8080")?
        .run()
        .await
}

JSON 序列化与反序列化

css 复制代码
use serde::{Serialize, Deserialize};

#[derive(Serialize, Deserialize)]
struct User {
    id: u32,
    name: String,
}

let user = User { id: 1, name: "Eric".to_string() };
let json = serde_json::to_string(&user).unwrap();
let back: User = serde_json::from_str(&json).unwrap();

3. 数据库

使用 sqlx

rust 复制代码
use sqlx::postgres::PgPoolOptions;

#[tokio::main]
async fn main() -> Result<(), sqlx::Error> {
    let pool = PgPoolOptions::new()
        .max_connections(5)
        .connect("postgres://user:password@localhost/dbname")
        .await?;

    let row: (i32,) = sqlx::query_as("SELECT 1")
        .fetch_one(&pool)
        .await?;
    println!("结果: {}", row.0);

    Ok(())
}
  • Diesel 也可用于类型安全的 ORM
  • 异步数据库操作可以使用 sqlx::query + await
  • 支持事务:
rust 复制代码
let mut tx = pool.begin().await?;
sqlx::query("INSERT INTO users (name) VALUES ($1)").bind("Eric").execute(&mut tx).await?;
tx.commit().await?;

4. 网络与异步

TCP 客户端

rust 复制代码
use tokio::net::TcpStream;
use tokio::io::{self, AsyncWriteExt};

#[tokio::main]
async fn main() -> io::Result<()> {
    let mut stream = TcpStream::connect("127.0.0.1:8080").await?;
    stream.write_all(b"Hello server!").await?;
    Ok(())
}

HTTP 请求(reqwest)

rust 复制代码
use reqwest::Error;

#[tokio::main]
async fn main() -> Result<(), Error> {
    let res = reqwest::get("https://www.rust-lang.org").await?;
    let body = res.text().await?;
    println!("{}", &body[0..100]);
    Ok(())
}

5. 测试与调试

单元测试

rust 复制代码
fn add(a: i32, b: i32) -> i32 { a + b }

#[cfg(test)]
mod tests {
    use super::*;

    #[test]
    fn test_add() {
        assert_eq!(add(2, 3), 5);
    }
}

集成测试

  • tests/ 文件夹下创建独立测试文件
  • cargo test 自动运行

代码检查与格式化

bash 复制代码
cargo clippy   # 静态分析
cargo fmt      # 自动格式化

练习项目

  1. 命令行文件管理工具
  • 支持复制、移动、删除文件
  • 参数解析:输入源路径和目标路径
  • 输出操作日志
  1. RESTful API 服务
  • CRUD 操作(Create, Read, Update, Delete)
  • 数据库持久化(Postgres / SQLite)
  • JSON 接口返回
  1. 简易聊天室
  • TCP 或 WebSocket 实现
  • 多线程/异步处理多客户端
  • 支持发送/接收消息
相关推荐
breeze_whisper3 小时前
当前端收到一个比梦想还大的数字:BigInt处理指南
前端·面试
小高0073 小时前
性能优化零成本:只加3行代码,FCP从1.8s砍到1.2s
前端·javascript·面试
子兮曰3 小时前
🌏浏览器硬件API大全:30个颠覆性技术让你重新认识Web开发
前端·javascript·浏览器
即兴小索奇3 小时前
Google AI Mode 颠覆传统搜索方式,它是有很大可能的
前端·后端·架构
大虾写代码3 小时前
nvm和nrm的详细安装配置,从卸载nodejs到安装NVM管理nodejs版本,以及安装nrm管理npm版本
前端·npm·node.js·nvm·nrm
星哥说事3 小时前
下一代开源 RAG 引擎,让你的 AI 检索与推理能力直接起飞
前端
....4923 小时前
Vue3 与 AntV X6 节点传参、自动布局及边颜色控制教程
前端·javascript·vue.js
machinecat3 小时前
Webpack模块联邦 - vue项目嵌套react项目部分功能实践
前端·webpack
今禾4 小时前
深入浅出:ES6 Modules 与 CommonJS 的爱恨情仇
前端·javascript·面试