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

【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.dtcms.com/a/277304.html

相关文章:

  • 深入解析Hadoop架构设计:原理、组件与应用
  • OpenLayers使用
  • (2)从零开发 Chrome 插件:实现 API 登录与本地存储功能
  • 音视频学习(三十八):像素与位深
  • 打破并发瓶颈:虚拟线程实现详解与传统线程模型的性能对比
  • QuickUnion优化及Huffman树
  • JS红宝书pdf完整版
  • JAVA生成PDF(itextpdf)
  • 为什么玩游戏用UDP,看网页用TCP?
  • [2025CVPR]GNN-ViTCap:用于病理图像分类与描述模型
  • MyBatis框架进阶指南:深入理解CRUD与参数映射
  • Redis集群方案——哨兵机制
  • 无需付费即可利用AI消除音频噪声和生成字幕
  • 《Linux篇》自动化构建-make/Makefile
  • GraphRAG Docker化部署,接入本地Ollama完整技术指南:从零基础到生产部署的系统性知识体系
  • AI抠图软件,本地运行超快速
  • 水往低处流,人也往低处走
  • 三种网络类型
  • 跨域中间件通俗理解
  • 教程:如何查看浏览器扩展程序的源码
  • Linux驱动11 --- buildroot杂项驱动开发方法
  • 网络资源模板--基于Android Studio 实现的音乐播放器App
  • 【Go语言-Day 19】深入理解Go自定义类型:Type、Struct、嵌套与构造函数实战
  • 系规备考论文:论IT服务知识管理
  • 20250711_Sudo 靶机复盘
  • vue的优缺点
  • React强大且灵活hooks库——ahooks入门实践之状态管理类hook(state)详解
  • 在NDK开发中如何正确创建JNI方法
  • Perl小骆驼学习笔记 - 9. 用正则表达式处理文本
  • 香港服务器Python自动化巡检脚本开发与邮件告警集成