当前位置: 首页 > backend >正文

【unitrix】 5.1 第二套类型级二进制数基本结构体(types2.rs)

一、源码

这段代码定义了一个类型级(type-level)的二进制数表示系统,使用Rust的泛型结构体来实现。

//! 类型级二进制数表示方案(第二套方案)
//!
//! 使用嵌套泛型结构体表示二进制数,支持整数和实数表示。
//!
//! # 表示规则
//!
//! - 整数部分使用嵌套的`B`结构体表示,例如:
//!   - `B<Null, O>` 表示 0
//!   - `B<Null, I>` 表示 -1
//!   - `B<B<Null, O>, I>` 表示 1
//!   - `B<B<Null, O>, O>` 表示 0 (高位0可以省略,实际为`B<Null, O>`)
//!
//! - 十进制科学计数法使用`D`结构体表示:
//!   - `D<I, E10>` 表示 I × 10^E10
//!   - 例如 `D<B<Null, I>, B<Null, I>>` 表示 -1 × 10^-1 = -0.1use crate::sealed::Sealed;/// 类型级二进制数结构体
///
/// # 泛型参数
/// - `H`: 高位部分
///   - `B<H, L>` 表示嵌套的高位
///   - `Null` 表示无更高位
/// - `L`: 低位部分
///   - `I` 表示1
///   - `O` 表示0
#[derive(Eq, PartialEq, Clone, Copy, Debug)]
pub struct B<H, L>(pub H, pub L);/// 十进制科学计数法表示
///
/// # 泛型参数
/// - `I`: 二进制整数部分
/// - `E10`: 10的幂次(使用二进制表示)
///
/// # 示例
/// ```
/// // -2 × 10^1 = -20.0
/// D<B<I, O>, B<O, I>>;
///
/// // 3 × 10^-2 = 0.03
/// D<B<B<B<Null, O>, I>, I>, B<B<Null, I>, O>>;
/// ```
#[derive(Eq, PartialEq, Clone, Copy, Debug)]
pub struct D<I, E10>(pub I, pub E10);/// 类型级比特位0(逻辑假)
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Debug, Default)]
pub struct O;/// 类型级比特位1(逻辑真)
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Debug, Default)]
pub struct I;/// 空类型标记,表示无更高位或无小数部分
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Debug, Default)]
pub struct Null;// 常用类型别名
pub type Zero = B<Null, O>;
pub type One = B<Null, I>;
pub type NegOne = B<Null, I>;// 实现Default trait
impl<H: Default, L: Default> Default for B<H, L> {fn default() -> Self {B(Default::default(), Default::default())}
}impl<I: Default, E10: Default> Default for D<I, E10> {fn default() -> Self {D(Default::default(), Default::default())}
}// 构造函数实现
impl<H, L> B<H, L> {/// 创建新的二进制数实例#[inline]pub const fn new(h: H, l: L) -> Self {B(h, l)}
}impl<I, E10> D<I, E10> {/// 创建新的十进制数实例#[inline]pub const fn new(int: I, exp: E10) -> Self {D(int, exp)}
}impl Null {/// 创建新的Null实例#[inline(always)]pub const fn new() -> Self {Null}
}impl O {/// 创建新的O实例#[inline(always)]pub const fn new() -> Self {O}
}impl I {/// 创建新的I实例#[inline(always)]pub const fn new() -> Self {I}
}// 密封标记实现
impl<H, L> Sealed for B<H, L> {}
impl<I, E10> Sealed for D<I, E10> {}
impl Sealed for Null {}
impl Sealed for O {}
impl Sealed for I {}

二、源码分析

  1. 核心设计理念
  • 使用嵌套的泛型结构体表示二进制数

  • 支持两种表示形式:

    • 纯二进制整数(B结构体)

    • 十进制科学计数法(D结构体)

  1. 主要结构体
B<H, L> - 二进制数表示
  • H: 高位部分,可以是另一个B结构体或Null(表示没有更高位)

  • L: 最低位,可以是O(0)或I(1)

  • 示例:

    • B<Null, O>: 0

    • B<Null, I>: -1

    • B<B<Null, O>, I>: 1 (01,高位0是符号位,不能省略)

    • B<B<Null, I>, O>: -2 (10)

D<I, E10> - 十进制科学计数法
  • I: 整数部分,用B结构体表示

  • E10: 10的幂次,也用B结构体表示

  • 示例:

    • D<B<Null, I>, B<Null, I>>: -1 × 10⁻¹ = -0.1

    • D<B<I, O>, B<O, I>>: -2 × 10¹ = -20.0

  1. 基本类型
  • O: 表示二进制位0

  • I: 表示二进制位1

  • Null: 表示空/无更高位

  1. 类型别名

pub type Zero = B<Null, O>;  // 0
pub type One = B<Null, I>;   // -1 (注意这里表示-1)
pub type NegOne = B<Null, I>; // -1
  1. 实现细节
  • 派生特质:

    • 为所有结构体派生了一系列标准特质(Eq, PartialEq, Clone, Copy, Debug等)
    • 实现了Default特质,使得这些类型可以默认构造
  • 构造函数:

    • 为每个结构体提供了new方法

    • 基本类型(Null, O, I)的构造函数是内联的

  • 密封特质(Sealed):

    • 实现了Sealed特质,这是一种设计模式,用于限制特质只能在当前crate内实现
  1. 表示规则特点
  • 使用补码表示法,最高位为1表示负数

  • 高位0可以省略(如B<Null, O>表示0而不是B<B<Null, O>, O>)

  • 高位1可以省略(如B<Null, I>表示-1而不是B<B<Null, I>, I>)

  • 十进制数使用科学计数法表示,便于表示实数

  1. 示例解读
  • B<B<B<Null, O>, I>, I>:

    • 从内到外:Null+O=0,B<Null,O>+I=01(1),B<B<Null,O>,I>+I=011(3)

    • 表示3

  • D<B<B<B<Null, O>, I>, I>, B<B<Null, I>, O>>:

    • 整数部分:011(3)

    • 指数部分:B<B<Null,I>,O>=10(-2)

    • 表示3 × 10⁻² = 0.03

这种类型级编程技术在Rust中常用于在编译期进行复杂的类型计算和验证,常见于嵌入式开发、数学库和高安全性应用中。

http://www.xdnf.cn/news/15320.html

相关文章:

  • Sqlmap工具下载及使用
  • 【算法】贪心算法入门
  • 算法学习笔记:19.牛顿迭代法——从原理到实战,涵盖 LeetCode 与考研 408 例题
  • 【SCI 4区推荐】《Journal of Visual Communication and Image Representation》
  • 代码随想录|图论|14有向图的完全可达性
  • 集训Demo1
  • CVPR2025 Mamba系列
  • JAVA--双亲委派机制
  • 维基艺术图片: python + scrapy 爬取图片
  • Linux系统中部署Redis详解
  • 算法练习6-大数乘法(高精度乘法)
  • RocketMQ-
  • 【字符串移位包含问题】2022-8-7
  • Opencv---深度学习开发
  • 单细胞入门(1)——介绍
  • 电商订单数据分析全流程:从数据处理到可视化洞察
  • 【PTA数据结构 | C语言版】车厢重排
  • Geant4 安装---Ubuntu
  • 【深度剖析】致力“四个最”的君乐宝数字化转型(下篇:转型成效5-打造数字化生存能力探索可持续发展路径)
  • 26. 删除有序数组中的重复项
  • 【MySQL笔记】事务的ACID特性与隔离级别
  • 详细理解向量叉积
  • 二分搜索 (左程云)
  • 【C/C++】编译期计算能力概述
  • uniapp弹出手机键盘,布局被顶飞,导致页面混乱问题
  • 使用Pycharm集成开发工具远程调试部署在虚拟机上的flask项目:超级详细的完整指南
  • Rust Web 全栈开发(六):在 Web 项目中使用 MySQL 数据库
  • Transforms
  • 单向链表反转 如何实现
  • JVM的垃圾回收算法和多种GC算法