news 2026/6/10 16:52:51

Android学Dart学习笔记第十三节 注解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Android学Dart学习笔记第十三节 注解

序言

是的没错,dart中也有注解,而且和java很像
比如这个@Deprecated、@override 都是非常熟悉的注解。
但是我们依然要过一下,目的不是深入了解dart中每个注解的实际使用场景,而是一种泛的了解。

文档描述

注解又叫Metadata

Use metadata to provide additional static information about your code. A metadata annotation begins with the character @, followed by either a reference to a compile-time constant (such as deprecated) or a call to a constant constructor.
译文:使用注解提供有关代码的额外静态信息。元数据注释以字符@开始,后面是对编译时常量的引用(例如deprecated)或对常量构造函数的调用
Metadata can be attached to most Dart program constructs by adding annotations before the construct’s declaration or directive.
译文:元数据可以通过在大多数Dart程序结构的声明或指令之前添加注释的方式附加到该结构中。

Built-in annotations 内置的注解

@Deprecated

Marks a declaration as deprecated, indicating it should be migrated away from, with a message explaining the replacement and potential removal date.
将声明标记为已弃用(deprecated),表示应该迁移该声明,并给出解释替换日期和潜在删除日期的消息。

@deprecated

和上面的很像,但是首字母不是大写
Marks a declaration as deprecated until an unspecified future release. Prefer using @Deprecated and providing a deprecation message.
将声明标记为废弃,直到未指定的未来版本。建议使用@Deprecated并提供弃用消息

和上面的主要区别就是@Deprecated可以提供弃用信息

@override

这是我们非常熟悉的,在dart中他的使用场景也是相同的
Marks an instance member as an override or implementation of a member with the same name from a parent class or interface.

将实例成员标记为父类或接口中具有相同名称的成员的覆盖或实现。

@pragma

Provides specific instructions or hints about a declaration to Dart tools, such as the compiler or analyzer.
提供有关Dart工具(如编译器或分析器)声明的特定指令或提示。

这个感觉是个新东西。暂时不深入,知道就行,

Analyzer-supported annotations (Analyzer 支持的注解详解)

Beyond providing support and analysis for the built-in annotations, the Dart analyzer provides additional support and diagnostics for a variety of annotations from package:meta.
除了为内置注释提供支持和分析外,Dart分析器还为来自meta包的各种注释提供了额外的支持和诊断。

@visibleForTesting

Marks a member of a package as only public so that the member can be accessed from the package’s tests. The analyzer hides the member from autocompletion suggestions and warns if it’s used from another package.

将包的成员标记为仅public,以便可以从包的测试中访问该成员。分析器会在自动补全建议中隐藏成员,并在其他包中使用该成员时发出警告。

通俗的讲就是虽然这个成员是public,但是有了这个注解标记之后他就不允许被其他的包中调用。
主要为了测试使用

@awaitNotRequired

Marks variables that have a Future type or functions that return a Future as not requiring the caller to await the Future. This stops the analyzer from warning callers that don’t await the Future due to the discarded_futures or unawaited_futures lints.

将具有Future类型的变量或返回Future的函数标记为不需要调用者等待Future。这阻止了分析器警告那些由于discarded_futures或unawaited_futures检查而不等待Future的调用者。

被调用者虽然是异步但不会返回结果,调用处无需await

Custom annotations

classMyAnnotation{finalString value;constMyAnnotation(this.value);}@MyAnnotation('hello')vara=0;@MyAnnotation('hello')voidmyFunction(){print('hello world');}voidmain(){myFunction();}
Specifying supported targets

指定注解支持的目标
To indicate the type of language constructs that should be annotated with your annotation, use the @Target annotation from package:meta.
要指定应该用注释标注的语言结构的类型,请使用package:meta中的@Target注释。

请看下面的例子

import'package:meta/meta_meta.dart';@Target({TargetKind.function,TargetKind.method})classMyAnnotation{finalString value;constMyAnnotation(this.value);}@MyAnnotation('hello')//The annotation 'MyAnnotation.new' can only be used on methods or top-level functions.dartinvalid_annotation_targetvara=0;@MyAnnotation('hello')voidmyFunction(){print('hello world');}

这是我们学习至今,首次用到其他包的内容我们需要添加依赖

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 21:25:46

告别单调界面:打造专属Media Player Classic-HC主题的完整指南

告别单调界面:打造专属Media Player Classic-HC主题的完整指南 【免费下载链接】mpc-hc Media Player Classic 项目地址: https://gitcode.com/gh_mirrors/mp/mpc-hc 你是否已经厌倦了默认播放器界面的单调外观?想让视频播放体验更具个性化但不知…

作者头像 李华
网站建设 2026/6/9 19:21:14

21、R语言统计计算全攻略:从基础到实战

R语言统计计算全攻略:从基础到实战 1. 用户自定义函数 R语言的强大之处不仅在于其丰富的内置函数,如 length 和 dim ,更在于用户能够自定义函数并在程序中调用。自定义函数的一般结构如下: my_func_name <- function([optional arguments]) {operationsreturn(v…

作者头像 李华
网站建设 2026/6/8 13:00:44

22、R语言统计计算与数据处理全解析

R语言统计计算与数据处理全解析 1. 统计计算基础 在R语言中,我们可以进行各种统计计算和数据可视化操作。以下是一些基本的数据生成和绘图示例。 1.1 数据生成 # generate data x <- 1:30 y <- rnorm(30, mean = x) y2 <- rnorm(30, mean = x, sd = sqrt(x))上述…

作者头像 李华
网站建设 2026/6/8 9:26:15

计算机毕业设计springboot淮师大学生成绩管理系统 基于 SpringBoot 的淮师大教务成绩分析与发布平台 淮阴师范学院学业成绩数字化综合管理平台

计算机毕业设计springboot淮师大学生成绩管理系统8qvsgqr1 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。当“一网通办”成为高校新常态&#xff0c;成绩却仍躺在 Excel 里来回…

作者头像 李华
网站建设 2026/6/7 5:56:21

6-5 WPS JS宏 集合成员迭代(随机生成试题)

示例&#xff1a;随机生成试题 题库&#xff1a; 结果&#xff1a; 代码&#xff1a; function 试卷(){ var arrSheets("题库").Range("a2:b21").Value(); var srnd(8,1,arr.length); var num1; var newarr[]; for(var v of s){ newarr.push([num,..…

作者头像 李华
网站建设 2026/6/10 4:56:01

46、IP 路由技术全面解析

IP 路由技术全面解析 1. 路由决策基础示例 为了更好地解释路由决策,我们先来看两个简单的例子。 第一个例子,主机 192.168.1.2 要向主机 192.168.1.3 发送数据包。此时,会查询 192.168.1.2 的路由表,首先查找是否有目标主机 192.168.1.3 的匹配项。由于没有这样的条目,…

作者头像 李华