@interface-什么?

发布于 2024-12-09 15:22:17 字数 232 浏览 1 评论 0原文

我知道什么是接口,但我对 java 的了解不够,不知道如何搜索我的答案。那么这是什么意思和作用:

public @interface ThreadSafe { }

// different file

@ThreadSafe
public class Model {

这行“@interface”是什么意思/做什么?当它应用在“@ThreadSafe”上方时,它意味着什么/做什么

I know what interfaces are, but I don't know enough about java to know how to search for my answer. So what does this mean and do:

public @interface ThreadSafe { }

// different file

@ThreadSafe
public class Model {

What does this line mean/do "@interface"? What does it mean/do when it's applied above "@ThreadSafe"

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

誰ツ都不明白 2024-12-16 15:22:17

这称为注释。您可能想查看 Java 教程。它对它们是什么以及如何使用有很好的解释。

https://docs.oracle.com/javase/tutorial/java/注释/index.html

This is called an annotation. You may want to look at the Java tutorial. It has a pretty good explanation of what they are and how they are used.

https://docs.oracle.com/javase/tutorial/java/annotations/index.html

爱你不解释 2024-12-16 15:22:17

许多注释取代了代码中的注释。

假设软件组传统上以提供重要信息的注释开始每个类的主体:

public class Generation3List extends Generation2List {
    // Author: John Doe
    // Date: 3/17/2002
    // Current revision: 6
    // Last modified: 4/12/2004
    // By: Jane Doe
    // Reviewers: Alice, Bill, Cindy  

    // class code goes here
}

要使用注释添加相同的元数据,必须首先定义注释类型。执行此操作的语法为:

@interface ClassPreamble {
   String author();
   String date();
   int currentRevision() default 1;
   String lastModified() default "N/A";
   String lastModifiedBy() default "N/A";
   // Note use of array
   String[] reviewers();
}

注释类型定义看起来类似于接口定义,其中关键字接口前面带有 at 符号 (@)(@ = AT,如注释类型中一样)。注释类型是一种界面形式,将在后面的课程中介绍。目前,您不需要了解接口。

前面的注释定义的主体包含注释类型元素声明,它看起来很像方法。请注意,它们可以定义可选的默认值。

定义注释类型后,您可以使用该类型的注释,并填写值,如下所示:

@ClassPreamble (
   author = "John Doe",
   date = "3/17/2002",
   currentRevision = 6,
   lastModified = "4/12/2004",
   lastModifiedBy = "Jane Doe",
   // Note array notation
   reviewers = {"Alice", "Bob", "Cindy"}
)

public class Generation3List extends Generation2List {
// class code goes here
}

Source: https://docs.oracle.com/javase/tutorial/java/annotations/declaring.html

Many annotations replace comments in code.

Suppose that a software group traditionally starts the body of every class with comments providing important information:

public class Generation3List extends Generation2List {
    // Author: John Doe
    // Date: 3/17/2002
    // Current revision: 6
    // Last modified: 4/12/2004
    // By: Jane Doe
    // Reviewers: Alice, Bill, Cindy  

    // class code goes here
}

To add this same metadata with an annotation, you must first define the annotation type. The syntax for doing this is:

@interface ClassPreamble {
   String author();
   String date();
   int currentRevision() default 1;
   String lastModified() default "N/A";
   String lastModifiedBy() default "N/A";
   // Note use of array
   String[] reviewers();
}

The annotation type definition looks similar to an interface definition where the keyword interface is preceded by the at sign (@) (@ = AT, as in annotation type). Annotation types are a form of interface, which will be covered in a later lesson. For the moment, you do not need to understand interfaces.

The body of the previous annotation definition contains annotation type element declarations, which look a lot like methods. Note that they can define optional default values.

After the annotation type is defined, you can use annotations of that type, with the values filled in, like this:

@ClassPreamble (
   author = "John Doe",
   date = "3/17/2002",
   currentRevision = 6,
   lastModified = "4/12/2004",
   lastModifiedBy = "Jane Doe",
   // Note array notation
   reviewers = {"Alice", "Bob", "Cindy"}
)

public class Generation3List extends Generation2List {
// class code goes here
}

Source: https://docs.oracle.com/javase/tutorial/java/annotations/declaring.html

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文