【Rust光年纪】提高开发效率:深入了解Rust语言中的数据库客户端和文件处理库
深入探索:Rust语言中多款数据库客户端与文件处理库详解
前言
在现代软件开发中,使用各种数据库和文件处理操作是非常常见的。Rust语言作为一种快速、安全、并发的系统编程语言,也拥有丰富的生态系统和库。本文将介绍几个用于Rust语言的数据库客户端和文件处理库,它们分别是.gitignore
文件解析库ignore
、文件glob匹配库glob
、Redis客户端Redis-rs
、PostgreSQL客户端postgres
、SQLite客户端rusqlite
以及ClickHouse客户端Clickhouse-rs
。
欢迎订阅专栏:Rust光年纪
文章目录
- 深入探索:Rust语言中多款数据库客户端与文件处理库详解
- 前言
- 1. ignore:一个用于Rust语言的.gitignore文件解析库
- 1.1 简介
- 1.1.1 核心功能
- 1.1.2 使用场景
- 1.2 安装与配置
- 1.2.1 安装指南
- 1.2.2 基本配置
- 1.3 API 概览
- 1.3.1 解析.gitignore文件
- 2. glob:一个用于Rust语言的文件glob匹配库
- 2.1 简介
- 2.1.1 核心功能
- 2.1.2 使用场景
- 2.2 安装与配置
- 2.2.1 安装指南
- 2.2.2 基本配置
- 2.3 API 概览
- 2.3.1 文件glob匹配
- 3. Redis-rs:一个用于Rust语言的Redis客户端
- 3.1 简介
- 3.1.1 核心功能
- 3.1.2 使用场景
- 3.2 安装与配置
- 3.2.1 安装指南
- 3.2.2 基本配置
- 3.3 API 概览
- 3.3.1 连接管理
- 3.3.2 数据操作
- 4. postgres:一个用于Rust语言的PostgreSQL客户端
- 4.1 简介
- 4.1.1 核心功能
- 4.1.2 使用场景
- 4.2 安装与配置
- 4.2.1 安装指南
- 4.2.2 基本配置
- 4.3 API 概览
- 4.3.1 连接管理
- 4.3.2 数据操作
- 5. rusqlite:一个用于Rust语言的SQLite客户端
- 5.1 简介
- 5.1.1 核心功能
- 5.1.2 使用场景
- 5.2 安装与配置
- 5.2.1 安装指南
- 5.2.2 基本配置
- 5.3 API 概览
- 5.3.1 连接管理
- 5.3.2 数据操作
- 6. Clickhouse-rs:一个用于Rust语言的ClickHouse客户端
- 6.1 简介
- 6.1.1 核心功能
- 6.1.2 使用场景
- 6.2 安装与配置
- 6.2.1 安装指南
- 6.2.2 基本配置
- 6.3 API 概览
- 6.3.1 连接管理
- 6.3.2 数据操作
- 总结
1. ignore:一个用于Rust语言的.gitignore文件解析库
1.1 简介
ignore 是一个用于 Rust 语言的 .gitignore 文件解析库,它可以帮助开发者解析 .gitignore 文件并进行相关操作。
1.1.1 核心功能
- 解析 .gitignore 文件
- 进行文件匹配与过滤
- 支持对 .gitignore 文件内容进行增删改查操作
1.1.2 使用场景
ignore 库适用于需要在 Rust 项目中处理 .gitignore 文件的开发者,能够方便地进行文件过滤与筛选操作。
1.2 安装与配置
1.2.1 安装指南
你可以通过 Cargo(Rust 的包管理工具)来安装 ignore 库。在项目的 Cargo.toml 文件中添加如下依赖:
[dependencies]
ignore = "0.6.17"
然后在项目中引入该库:
extern crate ignore;
更多关于 ignore 库的安装和使用信息,可以访问官方文档:ignore 官方文档
1.2.2 基本配置
ignore 库的基本配置通常不需要额外设置,只需要按照官方文档指引正确引入库即可。
1.3 API 概览
1.3.1 解析.gitignore文件
下面是一个简单的示例代码,演示了如何使用 ignore 库解析 .gitignore 文件,并进行文件匹配与过滤操作:
use ignore::Walk;fn main() {// 遍历当前目录及其子目录下所有文件for result in Walk::new(".") {match result {Ok(entry) => {if !entry.path().is_dir() {// 判断当前文件是否被 .gitignore 忽略if entry.path().to_str().map_or(false, |s| ignore::path::is_match(s, &["*.rs"])) {println!("Ignored: {:?}", entry.path());} else {println!("Not ignored: {:?}", entry.path());}}}Err(err) => println!("Error: {}", err),}}
}
通过以上代码,我们可以遍历当前目录及其子目录下的所有文件,并根据 .gitignore 文件的规则进行区分,输出被忽略的文件和未被忽略的文件。
更多关于 ignore 库的 API 细节,可以参考官方文档:ignore API 文档
2. glob:一个用于Rust语言的文件glob匹配库
2.1 简介
2.1.1 核心功能
glob
是一个用于 Rust 语言的文件 glob 匹配库,它提供了一种简单的方式来匹配文件名模式,类似于 shell 中的通配符。
2.1.2 使用场景
glob
库适用于需要按照特定模式匹配文件名的场景,比如扫描特定目录下的文件或者筛选出特定类型的文件等。
2.2 安装与配置
2.2.1 安装指南
你可以在 Cargo.toml 文件中添加以下依赖来安装 glob
:
[dependencies]
glob = "0.3"
然后在代码中引入 glob
库:
extern crate glob;
use glob::glob;
2.2.2 基本配置
基本配置方面,glob
库不需要额外的配置,只需要按照上述方式添加依赖并引入即可开始使用。
2.3 API 概览
2.3.1 文件glob匹配
glob
库提供了 glob
函数用于文件 glob 匹配。以下是一个简单的例子,展示如何使用 glob
匹配当前目录下所有 .txt
文件:
use glob::glob;fn main() {for entry in glob("*.txt").expect("Failed to read glob pattern") {match entry {Ok(path) => println!("{:?}", path.display()),Err(e) => println!("{:?}", e),}}
}
更多关于 glob
库的详细信息,可以访问官方文档:https://docs.rs/glob
以上是关于 glob
文件搜索库的简要介绍和基本用法,希望对你有所帮助!
3. Redis-rs:一个用于Rust语言的Redis客户端
3.1 简介
Redis-rs是一个用于Rust语言的Redis客户端,它提供了与Redis数据库进行交互的功能。
3.1.1 核心功能
- 通过Redis命令与Redis数据库进行通信
- 支持连接池管理
- 提供异步和同步API
3.1.2 使用场景
- 在Rust项目中需要与Redis数据库进行交互时
- 需要使用异步API来提高并发性能
3.2 安装与配置
3.2.1 安装指南
在Cargo.toml文件中添加以下依赖:
[dependencies]
redis = "0.20.0"
然后运行以下命令安装:
$ cargo build
3.2.2 基本配置
Redis-rs的基本配置可以通过创建RedisClient对象并设置连接参数来实现。具体配置参数可以参考官方文档 redis::Client。
3.3 API 概览
3.3.1 连接管理
Redis-rs提供了连接池管理功能,可以通过 get
方法从连接池中获取连接,并通过 clone
方法复制连接。具体示例代码如下:
use redis::Commands;fn main() {let client = redis::Client::open("redis://127.0.0.1/").unwrap();let mut con = client.get_connection().unwrap();// 执行Redis命令let _: () = con.set("my_key", 42).unwrap();
}
3.3.2 数据操作
Redis-rs支持所有的Redis数据操作命令,例如 SET
、GET
、DEL
等。以下是一个简单的示例,演示了如何使用Redis-rs进行数据操作:
use redis::Commands;fn main() {let client = redis::Client::open("redis://127.0.0.1/").unwrap();let mut con = client.get_connection().unwrap();// 设置键值对let _: () = con.set("my_key", "my_value").unwrap();// 获取键值对let result: String = con.get("my_key").unwrap();println!("Value of my_key: {}", result);
}
通过以上示例,我们可以看到Redis-rs提供了简单而强大的API,可以方便地在Rust项目中与Redis数据库进行交互。
以上就是Redis-rs客户端的简要介绍和基本用法示例。
相关链接:
- Redis-rs GitHub仓库
- Redis-rs 官方文档
4. postgres:一个用于Rust语言的PostgreSQL客户端
4.1 简介
Postgres 是一个为 Rust 语言开发的 PostgreSQL 客户端库,旨在提供高性能、易用且安全的 API。它允许 Rust 开发者轻松地与 PostgreSQL 数据库进行交互,并支持异步操作,是一个功能强大且灵活的工具。
4.1.1 核心功能
- 异步和同步连接
- 复杂参数绑定
- 支持自定义数据类型
- 事务支持
- 和其他 PostgreSQL 特性兼容
4.1.2 使用场景
Postgres 可以广泛应用于需要与 PostgreSQL 数据库进行交互的 Rust 项目中,特别是对于需要高性能和可靠性要求的项目,如 Web 服务、后端应用等。
4.2 安装与配置
安装 Postgres 可以通过 Cargo,在 Cargo.toml 文件中添加以下依赖项:
[dependencies]
postgres = "0.17.0"
4.2.1 安装指南
你可以通过 Cargo 来安装 Postgres,具体操作可以参考 Postgres 官方文档。
4.2.2 基本配置
在使用 Postgres 之前,你需要先确保已经安装了 Rust 环境,并且有可用的 PostgreSQL 数据库。在代码中,你需要根据实际情况配置数据库连接参数,如地址、用户名、密码等信息。
4.3 API 概览
Postgres 提供了丰富的 API 用于连接管理和数据操作。
4.3.1 连接管理
下面是一个简单的示例,演示了如何建立一个数据库连接:
use postgres::{Client, NoTls};fn main() {let client = Client::connect("host=localhost user=postgres dbname=mydb", NoTls).expect("Failed to connect to database");// 使用连接执行查询等操作
}
你可以通过 Postgres 官方文档 获取更多关于连接管理的信息。
4.3.2 数据操作
Postgres 提供了丰富的 API 用于数据操作,包括执行 SQL 查询、事务管理等功能。下面是一个示例,演示了如何执行简单的 SQL 查询操作:
use postgres::{Client, NoTls};fn main() {let mut client = Client::connect("host=localhost user=postgres dbname=mydb", NoTls).expect("Failed to connect to database");for row in &client.query("SELECT id, name FROM users", &[]).unwrap() {let id: i32 = row.get(0);let name: &str = row.get(1);println!("id: {}, name: {}", id, name);}
}
以上示例展示了如何使用 Postgres 执行一条简单的查询,并处理查询结果。你可以根据具体的业务需求,使用 Postgres 提供的丰富 API 来实现更复杂的数据操作。
5. rusqlite:一个用于Rust语言的SQLite客户端
5.1 简介
rusqlite 是一个为 Rust 语言设计的 SQLite 客户端,它提供了连接 SQLite 数据库、执行 SQL 命令以及处理查询结果的功能。
5.1.1 核心功能
- 连接 SQLite 数据库
- 执行 SQL 命令
- 处理查询结果
5.1.2 使用场景
rusqlite 可以被用于 Rust 项目中需要使用嵌入式数据库的场景,例如小型 Web 应用、桌面应用或者嵌入式系统中。
5.2 安装与配置
5.2.1 安装指南
你可以在 Cargo.toml 中添加 rusqlite 作为依赖项:
[dependencies]
rusqlite = "0.25.0"
然后通过 Cargo 来进行安装:
$ cargo build
5.2.2 基本配置
在使用 rusqlite 之前,你需要确保已经安装了 SQLite。另外,你需要在代码中引入 rusqlite crate:
extern crate rusqlite;
use rusqlite::{Connection, Result};
5.3 API 概览
5.3.1 连接管理
使用 Connection
结构体来管理与 SQLite 数据库的连接。下面是一个示例代码:
use rusqlite::Connection;fn main() -> rusqlite::Result<()> {let conn = Connection::open("test.db")?;// ...Ok(())
}
更多关于连接的操作可以参考 rusqlite 官方文档。
5.3.2 数据操作
使用 Connection
执行 SQL 命令和处理查询结果。以下是一个简单的示例:
use rusqlite::Connection;fn main() -> rusqlite::Result<()> {let conn = Connection::open_in_memory()?;conn.execute("CREATE TABLE person (id INTEGER PRIMARY KEY,name TEXT NOT NULL,age INTEGER NOT NULL)",[],)?;conn.execute("INSERT INTO person (name, age) VALUES (?1, ?2)",&["Bob", &30],)?;Ok(())
}
更多关于数据操作的细节可以参考 rusqlite 官方文档。
6. Clickhouse-rs:一个用于Rust语言的ClickHouse客户端
6.1 简介
6.1.1 核心功能
clickhouse-rs 是一个为 Rust 语言开发的 ClickHouse 客户端,它提供了连接到 ClickHouse 数据库并执行查询的功能。该客户端支持异步和同步操作。
6.1.2 使用场景
- 高性能数据存储和分析:可以利用 clickhouse-rs 客户端通过 Rust 语言对 ClickHouse 数据库进行高效地数据读取和写入。
- 大数据处理:由于 ClickHouse 的特性,可以使用 clickhouse-rs 在大规模数据集上执行复杂的查询和分析操作。
6.2 安装与配置
6.2.1 安装指南
您可以在 Cargo.toml 中添加以下依赖来安装 clickhouse-rs:
[dependencies]
clickhouse = "0.2"
点击 这里 查看更多详情。
6.2.2 基本配置
在使用 clickhouse-rs 之前,需要确保已经安装了 Rust 编程语言的环境,并且具备对应的 ClickHouse 数据库连接权限。
6.3 API 概览
6.3.1 连接管理
use clickhouse::Client;#[tokio::main]
async fn main() {let client = Client::default().with_url("http://localhost:8123/");let mut conn = client.get_handle().await.expect("failed to create connection");// 执行 SQL 查询let result = conn.query("SELECT * FROM my_table").await.expect("query failed");println!("{:?}", result);
}
以上代码演示了如何创建 clickhouse-rs 的客户端连接,并执行简单的 SQL 查询。点击 这里 查看更多 API 详细信息。
6.3.2 数据操作
use clickhouse::types::Block;
use clickhouse::Client;#[tokio::main]
async fn main() {let client = Client::default().with_url("http://localhost:8123/");let mut conn = client.get_handle().await.expect("failed to create connection");// 创建表结构let block = Block::new().column("id", vec![1, 2, 3]).column("name", vec!["Alice", "Bob", "Carol"]);// 写入数据conn.insert("default.my_table", block).await.expect("insert failed");
}
以上代码展示了如何使用 clickhouse-rs 将数据插入到 ClickHouse 数据库中。点击 这里 查看更多 API 详细信息。
总结
本文介绍了多个用于Rust语言的数据库客户端和文件处理库,涵盖了.gitignore
文件解析库ignore
、文件glob匹配库glob
、Redis客户端Redis-rs
、PostgreSQL客户端postgres
、SQLite客户端rusqlite
以及ClickHouse客户端Clickhouse-rs
。通过本文的阅读,读者可以更全面地了解这些库的特性和用法,为日后的Rust语言开发项目提供参考和指导。
相关文章:

【Rust光年纪】提高开发效率:深入了解Rust语言中的数据库客户端和文件处理库
深入探索:Rust语言中多款数据库客户端与文件处理库详解 前言 在现代软件开发中,使用各种数据库和文件处理操作是非常常见的。Rust语言作为一种快速、安全、并发的系统编程语言,也拥有丰富的生态系统和库。本文将介绍几个用于Rust语言的数据…...

【自动驾驶】控制算法(一)绪论与前期准备
写在前面: 🌟 欢迎光临 清流君 的博客小天地,这里是我分享技术与心得的温馨角落。📝 个人主页:清流君_CSDN博客,期待与您一同探索 移动机器人 领域的无限可能。 🔍 本文系 清流君 原创之作&…...

CSDN创作一周年总结
一周年总结 文章目录 一周年总结我的第一篇文章这一年我收获到了什么?1.培养了逻辑能力2.形成了自己的知识库,知识网络3.功利性的收获 我的第一篇文章 不知不觉之间,也已经过去一年了。还记得第一次决定在csdn上写博客,是因为进入…...

World of Warcraft [CLASSIC] the Eye of Eternity [EOE] P1-P2
World of Warcraft [CLASSIC] the Eye of Eternity [EOE] 永恒之眼(蓝龙) 第一阶段 第二阶段 第三阶段 载具1-6技能介绍 World of Warcraft [CLASSIC] the Eye of Eternity [EOE]_永恒之眼 eoe-CSDN博客 永恒之眼怎么出副本呢,战斗结束&am…...

一键翻译全球:多语言支持下的英文翻译工具
随着科技的飞速发展,一系列英文翻译工具应运而生,它们以人工智能为驱动,极大地简化了跨语言交流的过程。本文将带您一窥英文翻译工具探索那些能够帮助我们跨越语言鸿沟的神奇工具。 1.福昕在线翻译 链接直达>>https://fanyi.pdf365.c…...

水战再起波澜,“怡宝”要下好怎样一盘棋?
不少投资者常把那些刚需性强、永远也不可能淘汰的产业称为“日不落产业”,从细分板块来看,水无疑具有一定代表性。农夫山泉掌门人钟晱晱曾直言:“我选择了一个日不落的产业,你永远要喝水,不可能不喝水。” 多年下来&a…...

使用maven快速生成打包文件3
这里再介绍一种打包方式,依赖包分开打包,直接将需要部署的文件打包成一个要锁文件,比如kafka-roma-bin.tar.gz,这里需要两个文件,一个pom2.xml,一个package.xml。 pom2.xml <?xml version"1.0&q…...

Excel技巧(一)
快捷键技巧 原文链接 选取某一行的数据直到最后一行:【CTRL SHIFT ↓ 】或者选取一行后按住SHIFT键,双击下边线就可以快速选取区域。 如果表格中有多行空行,可以先按CTRL SHIFT END,再按CTRL SHIFT 上下键调整,…...

C语言:文件复制
文本文件复制: #include<stdio.h>int main() {FILE* pFile1 NULL;FILE* pFile2 NULL;fopen_s(&pFile1,"D:\\11111.txt","r");fopen_s(&pFile2,"D:\\222.txt", "w");char c;while((cfgetc(pFile1))!EOF){f…...

谈谈建筑项目管理:类型、流程和工具
无论是在材料采购还是供应商管理方面,确保建筑项目按计划进行并控制在预算内始终是一项挑战。 如今,建筑项目管理正逐步采用软件驱动的方法来提升其效率。这一转型显著优化了项目规划、调度和资源配置,使建筑管理更加精确和高效。 什么是建…...

【Vue】生命周期函数
系列文章目录 第五章 生命周期函数 文章目录 系列文章目录 生命周期函数代表的是Vue实例,或者是Vue组件,在网页中各个生命阶段所执行的函数。生命周期函数可以分为创建阶段、挂载阶段、更新阶段以及卸载阶段。 创建阶段:setup挂载阶段&…...

C++系列-文件操作
文件操作 文件类型文本文件二进制文件 文件操作的三大类文件的打开方式ios::app(append)和 ios::ate(at end) 写文件写文件文件步骤读文件文件步骤二进制文件读写写一般数据写特殊数据 程序运行时产生的数据都属于临时数据,一旦程序运行完毕,就会释放&am…...

ES6解构赋值详解;全面掌握:JavaScript解构赋值的终极指南
目录 全面掌握:JavaScript解构赋值的终极指南 一、数组解构赋值 1、基本用法 2、跳过元素 3、剩余元素 4、默认值 二、对象解构赋值 1、基本用法 2、变量重命名 3、默认值 4、嵌套解构 三、复杂的嵌套结构解构 四、函数参数解构赋值 1、对象解构作为函…...

2-73 基于matlab的weber能量法求解齿轮时变啮合刚度的程序
基于matlab的weber能量法求解齿轮时变啮合刚度的程序,能够跑出刚度图,通过求解轮齿部分变形、基体变形及局部接触变形这三部分的变形,进而求得综合弹性变形,最终求出时变啮合刚度。程序已调通,可直接运行。 2- 73 齿轮…...

[C++]set和map的介绍及使用
关于set和map的接口函数部分,只重点介绍一些相较于别的容器有特殊地方的接口,set和map的接口可以触类旁通。 一、概念 (一)、关联式容器 关联式容器存储的元素是一个个的键值对<key,value>。通过键(key&#x…...

【MySQL】MySQL学习笔记(持续更新)
1. 安装MySQL(windows环境) (1)在http://www.mysql.com下载*.msi的安装文件,并运行安装: 如:mysql-installer-community-8.0.39.0.msi 全部安装包含如下内容: …...

ArcGIS如何将投影坐标系转回为地理坐标系
有时候两个数据,一个为投影坐标系,另一个为地理坐标系时,在GIS软件中位置无法叠加到一起,这需要将两个或多个数据的坐标系统一,可以直接将地理坐标系的数据进行投影,或将投影坐标系转为地理坐标系。下面介绍…...

Parallels Desktop 19 for Mac 安装虚拟机需要激活吗
Parallels Desktop 19 for Mac 乃是一款适配于 Mac 的虚拟化软件。它能让您在 Mac 计算机上同时运行多个操作系统。您可借此创建虚拟机,并于其中装设不同的操作系统,如 Windows、Linux 或 macOS。使用 Parallels Desktop 19 mac 版时,您可在 …...

wps题注为表格或图片编号
word中为表格添加题注: 问题:多次或多人编辑导致--序号不能联动更新(域代码不一致,如图) 所以是否可以批量替换word里的域代码?如果可以这问题就解决了————失败 解决办法: 如图,复制表头&…...

集成测试怎么做?
任何产品想要长期保持高质量运行,集成测试正是实现这一目标必不可少的工具。 本文重点介绍集成测试实现的流程,而非测试工具本身。我们的目的是聚焦于创建测试过程中你可能遇到的问题,以便你能自主地推进工作。 缺陷的成本 细节决定成败&a…...

java mybatis 使用work id
在 MyBatis-Plus 中,如果你想要使用 WORK_ID 作为 ID 生成策略的一部分,通常是指使用雪花算法(Snowflake Algorithm)的一种变体来生成全局唯一 ID。雪花算法能够生成一个递增的 64 位整数作为 ID,这种 ID 在分布式系统…...

MySQL 的子查询(Subquery)
在数据库查询中,有时候我们需要从一个查询的结果集中获取数据,再将这些数据作为另一个查询的一部分来使用。MySQL 提供了子查询(Subquery)这一强大工具,帮助我们实现嵌套查询,从而解决复杂的数据检索需求。…...

后端Web之数据库(以MySQL为例)
目录 1.概述 2.MySQL 3.DDL 4.DML 5.DQL 1.概述 对于我们自己写的一些小功能,数据一般存储在文件中,比如XML文件。而在实际项目中,数据都是存放在数据库中的。数据库(DataBase )是一个存储数据的集合,…...

委托发布 | 进迭时空联合移动云能力中心实现业界首个RISC-V IO虚拟化方案
仟江水商业电讯(8月22日 北京 委托发布)虚拟化是云计算技术基石,是RISC-V走进云计算等高性能计算场景的必然要求。RISC-V国际基金会2021年制定了Hypervisor 1.0规范,2023年制定了AIA 1.0规范和IOMMU 1.0规范,这3个规范…...

3-Electron打开新窗口,并跳转到指定的路由
需要配置路由。src/router/index.js {path: "/selectMode",name: "selectMode",component: () > import("//view/selectMode/index.vue"),},src/**.vue import { ipcRenderer } from "electron";const openNewTab () > {let p…...

comfyUI和SD webUI都有哪些差别呢?
ComfyUI和SD WebUI都是用于AI绘画的用户界面,它们各自有着不同的特点和适用场景。以下是两者之间的一些关键差别: 1、用户体验与界面友好性: SD WebUI(Stable Diffusion Web User Interface)以其直观易用著称,特别受初…...

MySql中常用的sql语句大全(工作常用篇)
1. DDL 1.1 操作数据库 --创建库 create database 库名;--创建库时判断库是否存在,不存在则创建 create database if no exists 库名;--查看所有数据库 show databases;--使用指定数据库 use 库名;--查看当前指定数据库包含的数据表 show tables;--查看数据库的结…...

React+Vis.js(03):vis.js设置节点形状
文章目录 Vis支持的形状类型代码实现完整代码实现效果Vis支持的形状类型 circle(圆形)box(盒子)dot(点)star(五角星)triangle(三角形)ellipse(椭圆形)triangleDown(倒三角形)diamond(菱形)代码实现 通过shape属性来定义每个节点的形状 const nodes = new vis…...

Pod和Deployment
一、pod Evicted状态: 在Kubernetes中,当节点资源紧张时,Kubelet可能会驱逐节点上的一些Pods以释放资源。当这种情况发生时,Pod的状态会被设置为"Evicted"。 1.pod的探针 1.就绪性探针: 一般用于探测容器…...

7. 数据结构—二叉树(链式存储)
1. 内容 包括链式存储二叉树的 递归与非递归实现的先序、中序以及后序遍历、层序遍历、创建二叉树、计算深度、总节点数。 2. 实现代码 注意:只是伪代码,如果想要运行的话在细节方面需要自己修正,栈和队列的方法实现需要引进或者使用其C自…...