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

Rust #[] 语法

在 Rust 中,#[] 语法用于 属性(Attributes),这是一种特殊的元数据注解,用于向编译器提供额外信息或修改代码的行为。它们类似于其他语言中的注解(如 Java)或装饰器(如 Python)。

核心概念

  1. 基本形式

    • 外部属性#[attr](应用于后面的代码项)

    • 内部属性#![attr](应用于整个作用域,如模块或 crate)

  2. 常见用途

    • 条件编译(#[cfg]

    • 禁用编译器警告(#[allow]

    • 实现 trait(#[derive]

    • 标记测试函数(#[test]

    • 配置优化(#[inline]

    • 链接外部库(#[link]


深入示例解析

1. 条件编译 #[cfg]
#[cfg(target_os = "linux")]
fn linux_only() {println!("Running on Linux!");
}#[cfg(not(target_os = "linux"))]
fn not_linux() {println!("Not on Linux!");
}
  • 作用:只在特定平台/条件下编译代码

  • 等价命令rustc --cfg 'target_os="linux"'


2. 派生 Trait #[derive]
#[derive(Debug, Clone, PartialEq)]
struct Point {x: i32,y: i32,
}
  • 效果:自动实现 Debug(打印)、Clone(克隆)、PartialEq(比较)等 trait

  • 原理:编译器生成默认实现代码


3. 禁用警告 #[allow]
#[allow(dead_code)] // 忽略"未使用代码"警告
fn unused_function() {}

4. 测试函数 #[test]

#[test]
fn test_addition() {assert_eq!(2 + 2, 4);
}
  • 运行测试:cargo test

  • 标记为测试的函数会被编译进单独的可执行文件


5. 内联优化 #[inline]
#[inline(always)] // 强制内联展开
fn add(a: i32, b: i32) -> i32 {a + b
}

特殊属性

属性作用示例
#[no_mangle]禁用名称修饰(用于 FFI)#[no_mangle] pub extern fn
#[repr(C)]指定 C 兼容内存布局#[repr(C)] struct Data
#![feature]启用实验性功能(仅 nightly)#![feature(specialization)]
#![crate_type]指定 crate 类型(lib/bin)#![crate_type = "lib"]

自定义属性(高级)

通过过程宏可创建自定义属性:

// 自定义属性宏(需在单独 crate 中定义)
#[proc_macro_attribute]
pub fn log_call(_attr: TokenStream, item: TokenStream) -> TokenStream {// 自动插入日志代码let input = parse_macro_input!(item as ItemFn);/* ...生成新代码... */
}

使用示例:

#[log_call]
fn expensive_calculation() { ... }
// 编译时会自动插入日志代码

最佳实践

  1. 优先使用标准属性(如 derivecfg

  2. 谨慎使用 unsafe 相关属性(如 repr

  3. 避免过度使用 inline(编译器通常能更好决策)

  4. 条件编译时提供兜底实现 提升可移植性

        属性是 Rust 元编程的核心工具之一,合理使用可以极大提升代码的表达力和灵活性,同时保持安全性。

http://www.dtcms.com/a/270521.html

相关文章:

  • PHP语法高级篇(一):日期时间处理和包含文件
  • 【系统与工具】Linux——Linux简介、安装、简单使用
  • 详解Kafka重平衡机制详解
  • MySQL8.0基于GTID的组复制分布式集群的环境部署
  • mysql互为主从失效,重新同步
  • 超越公有云:在裸金属服务器上构建低成本、高性能的静态资源服务
  • 创客匠人:创始人 IP 打造中 “放下身段” 的深层逻辑
  • 身份证识别api-便捷生活与安全社会的双重保障
  • 神经网络简介
  • 鸿蒙商城开发:ZKmall开源商城系统特性适配与性能优化
  • 7.神经网络基础
  • 【JavaEE进阶】图书管理系统(未完待续)
  • 【学习笔记】OkHttp源码架构解析:从设计模式到核心实现
  • 保姆级安装 Ruby 环境下载及安装教程, RubyInstaller下载及安装教程
  • Javaweb - 10.7 乱码和路径问题
  • 影石(insta360)X4运动相机视频删除的恢复方法
  • SHA-256算法详解——Github工程结合示例和动画演示
  • 中望CAD2026亮点速递(5):【相似查找】高效自动化识别定位
  • Python(30)基于itertools生成器的量子计算模拟技术深度解析
  • 【SQL】使用UPDATE修改表字段的时候,遇到1054 或者1064的问题怎么办?
  • (八)PS识别:使用 Python 自动化生成图像PS数据集
  • Linux驱动05 --- TCP 服务器
  • 分库分表之实战-sharding-JDBC绑定表配置实战
  • uniapp+vue3+ts项目:实现小程序文件下载、预览、进度监听(含项目、案例、插件)
  • PostgreSQL如何进行跨服务器迁移数据
  • ARIA UWB安全雷达主要产品型号与核心功能全解析
  • 【数字后端】- Standard Cell Status
  • 亚马逊广告进阶指南:CPC与竞价的底层逻辑
  • 游戏开发学习记录
  • 基于Flask 3.1和Python 3.13的简易CMS