13个版本 (4个破坏性更新)

0.5.0 2022年1月25日
0.4.0 2022年1月14日
0.3.2 2022年1月9日
0.3.1 2021年12月22日
0.1.3 2021年11月24日

#315内存管理

Download history 25/week @ 2024-03-14 27/week @ 2024-03-21 45/week @ 2024-03-28 33/week @ 2024-04-04 28/week @ 2024-04-11 35/week @ 2024-04-18 27/week @ 2024-04-25 24/week @ 2024-05-02 26/week @ 2024-05-09 24/week @ 2024-05-16 26/week @ 2024-05-23 23/week @ 2024-05-30 16/week @ 2024-06-06 24/week @ 2024-06-13 37/week @ 2024-06-20 8/week @ 2024-06-27

每月90次下载
用于 10 个crate (3个直接使用)

MIT 协议

53KB
1K SLoC

crates.io

关于

NSTD是一个旨在跨平台的库,相当安全(任何可能失败的功能都将返回一个错误代码以指示它是否成功),同时拥有众多特性和功能。目标是有一个适用于任何平台、任何语言和任何用例的单一API。

平台支持

可以在任何地方使用core模块。它不依赖于任何其他库,包括标准库(除了头文件stddef.hstdint.h)。其他模块在大多数平台上工作,并已测试可以在Windows、macOS、Linux和Redox上构建。

模块概述

  • nstd - 基于CFFI的跨平台库。
    • alloc - 堆分配。
      • allocator - 用于内存分配的自定义vtable结构。
      • heap - 类似于Rust的Box。
    • audio - 音频I/O。
      • def - 常用的音频相关类型。
      • device - 音频I/O设备句柄。
      • host - 平台的音频宿主。
      • player - 音频播放器。
      • queue - 音频流队列。
      • stream - 音频I/O流。
    • collections - 集合类型。
      • bit_mask - 具有小内存占用的小型可定制位掩码。
      • rc - 通过引用计数共享内存。
      • stack - 可增长和缩小的堆栈数组类型。
    • core - 包含不需要操作系统的模块。
      • char_types - 特定于字符类型的函数。
      • cstr - C字符串检查。
      • def - 常用typedef。
      • float_types - 特定于浮点类型的函数。
      • int_types - 整数类型特定函数。
      • math - 低级数学。
      • platform - 平台识别。
      • pointer - 指针类型。
      • range - 范围类型。
      • slice - 内存视图。
      • str - UTF-8 字符串切片类型。
    • env - 环境特定功能和识别。
    • events - 事件循环。
      • def - 事件系统使用的常用类型。
      • device_id - 用于识别设备的类型。
      • window_id - 用于识别窗口的类型。
    • fs - 文件系统。
      • file - 文件 I/O。
    • gl - 低级图形库。
      • buffer - GPU VRAM 缓冲区。
      • command - 设备命令。
        • buffer - GPU 命令缓冲区。
        • encoder - GPU 命令编码器。
      • def - 常用的图形相关类型。
      • device - 用于处理图形设备的模块。
        • handle - 图形设备的句柄。
        • info - 图形设备的信息。
      • instance - wgpu 的实例。
      • render - 渲染。
        • pass - 包含与渲染传递一起工作的函数。
        • pipeline - 渲染管线。
      • shader - GPU 着色器程序。
        • module - 着色器模块。
      • state - 图形库的状态机。
      • surface - 与显示表面的交互。
        • config - 表面的配置。
        • texture - 表面纹理。
      • texture - 用于处理纹理的模块。
        • format - 纹理的数据格式。
        • view - 纹理视图。
    • gui - 图形用户界面库。
      • display - 显示/监视器句柄。
      • window - 窗口和表单。
    • image - 原始图像数据 I/O。
    • input - 键盘/鼠标输入。
      • key - 键盘类型。
      • mouse - 鼠标类型。
    • io - 标准I/O。
      • input_stream - 输入流类型。
      • io_stream - 输入和输出的流类型。
      • output_stream - 输出流类型。
      • stderr - 标准错误流。
      • stdin - 标准输入流。
      • stdout - 标准输出流。
      • stream - 基础流类型。
    • math - 高级数学。
    • net - 网络。
      • tcp - TCP 网络。
      • udp - UDP 网络。
    • os - 操作系统特定功能。
      • linux - Linux 的操作系统支持。
        • alloc - Linux 的低级内存分配。
      • windows - Windows 的操作系统支持。
        • alloc - Windows 的低级内存分配。
          • heap - Windows 堆管理。
        • def - 常用的 Windows 类型定义。
        • io - Windows 标准I/O。
        • thread - Windows 的线程支持。
    • proc - 进程管理。
    • rand - 随机值生成。
    • string - 动态大小的UTF-8编码字符串。
    • thread - 线程API。
    • time - 获取系统时间的库。
    • vec - 动态大小的数组。

如何构建

cargo build --release --features ""

在“--features”之后,在引号内,您可以通过空格分隔每个模块,并使用“nstd_”作为前缀进行列出,尽管 nstd_os 模块略有不同,并且有其自己的功能,如 nstd_os_alloc,这可以单独启用,nstd_os 不是必需的。nstd_core 默认构建。如果您想将 nstd 构建为 C 库,也应使用 "clib" 功能,以构建适用于 C ABI 的模块。

示例

cargo build --release --features "clib nstd_alloc nstd_os nstd_os_io nstd_string"

或者您也可以使用

cargo build --release --all-features

来构建所有模块。

依赖项

~190KB