Java學習手冊:Java反射與注解

Java反射與注解

Java反射(Reflection)和注解(Annotation)是Java語言中兩個強大的特性,它們在框架開發和復雜應用中扮演著重要角色。反射允許程序在運行時檢查和操作類、對象、接口、字段和方法,而注解則提供了一種元數據形式,用于為代碼提供附加信息。本文將深入探討Java反射和注解的核心概念、用法及實際應用場景。

Java反射

反射是Java提供的一種在運行時檢查和操作類、對象、接口、字段和方法的能力。通過反射,可以在運行時獲取類的信息并動態調用方法、訪問字段等。反射的主要類位于java.lang.reflect包中。

獲取類信息

反射的核心是通過Class對象獲取類的信息。每個類都有一個Class對象,可以通過類名.class對象.getClass()Class.forName()獲取。

示例代碼

import java.lang.reflect.Method;public class ReflectionExample {public static void main(String[] args) {try {// 獲取Class對象Class<?> clazz = Class.forName("java.lang.String");// 獲取類名System.out.println("類名: " + clazz.getName());// 獲取所有公共方法Method[] methods = clazz.getMethods();System.out.println("公共方法:");for (Method method : methods) {System.out.println(method.getName());}// 獲取特定方法Method method = clazz.getMethod("length");System.out.println("方法: " + method.getName());} catch (ClassNotFoundException | NoSuchMethodException e) {e.printStackTrace();}}
}
動態調用方法

反射允許在運行時動態調用對象的方法。

示例代碼

import java.lang.reflect.Method;public class InvokeMethodExample {public static void main(String[] args) {try {// 獲取Class對象Class<?> clazz = Class.forName("java.lang.String");// 創建對象Object obj = clazz.getDeclaredConstructor(new Class<?>[]{char[].class}).newInstance(new char[]{'H', 'e', 'l', 'l', 'o'});// 獲取方法并調用Method method = clazz.getMethod("length");int length = (int) method.invoke(obj);System.out.println("字符串長度: " + length);} catch (Exception e) {e.printStackTrace();}}
}
訪問私有字段和方法

反射可以突破訪問限制,訪問私有字段和方法。

示例代碼

import java.lang.reflect.Field;
import java.lang.reflect.Method;public class AccessPrivateExample {private String privateField = "私有字段";private void privateMethod() {System.out.println("私有方法被調用");}public static void main(String[] args) {try {// 獲取Class對象Class<?> clazz = Class.forName("AccessPrivateExample");// 創建對象Object obj = clazz.getDeclaredConstructor().newInstance();// 訪問私有字段Field field = clazz.getDeclaredField("privateField");field.setAccessible(true);System.out.println("私有字段值: " + field.get(obj));// 調用私有方法Method method = clazz.getDeclaredMethod("privateMethod");method.setAccessible(true);method.invoke(obj);} catch (Exception e) {e.printStackTrace();}}
}

Java注解

注解是Java 5引入的一種元數據形式,用于為代碼提供附加信息。注解本身不會直接影響代碼的行為,但可以通過反射機制在運行時讀取和處理這些注解。

內置注解

Java提供了一些內置注解,用于常見的用途:

  • @Override:表示方法重寫。
  • @Deprecated:表示方法或類已過時。
  • @SuppressWarnings:抑制編譯器警告。

示例代碼

public class DeprecatedExample {@Deprecatedpublic void oldMethod() {System.out.println("這個方法已過時");}public static void main(String[] args) {DeprecatedExample example = new DeprecatedExample();example.oldMethod(); // 編譯器會發出警告}
}
自定義注解

開發者可以創建自定義注解,用于特定的業務邏輯。

示例代碼

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;// 定義注解
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
@interface MyAnnotation {String value();
}// 使用注解
public class AnnotationExample {@MyAnnotation("Hello, Annotation!")public void annotatedMethod() {System.out.println("這是一個被注解的方法");}public static void main(String[] args) {try {// 獲取Class對象Class<?> clazz = Class.forName("AnnotationExample");// 獲取方法Method method = clazz.getMethod("annotatedMethod");// 檢查方法是否被注解if (method.isAnnotationPresent(MyAnnotation.class)) {MyAnnotation annotation = method.getAnnotation(MyAnnotation.class);System.out.println("注解值: " + annotation.value());}// 調用方法Object obj = clazz.getDeclaredConstructor().newInstance();method.invoke(obj);} catch (Exception e) {e.printStackTrace();}}
}

反射與注解的結合

反射和注解經常結合使用,特別是在框架開發中。通過反射,可以在運行時讀取注解信息并執行相應的邏輯。

示例代碼

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.lang.reflect.Method;// 定義注解
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
@interface MyAnnotation {String value();
}// 使用注解
public class FrameworkExample {@MyAnnotation("Hello, Framework!")public void process() {System.out.println("處理業務邏輯");}public static void main(String[] args) {try {// 獲取Class對象Class<?> clazz = Class.forName("FrameworkExample");// 創建對象Object obj = clazz.getDeclaredConstructor().newInstance();// 獲取所有方法Method[] methods = clazz.getMethods();for (Method method : methods) {// 檢查方法是否被注解if (method.isAnnotationPresent(MyAnnotation.class)) {MyAnnotation annotation = method.getAnnotation(MyAnnotation.class);System.out.println("注解值: " + annotation.value());method.invoke(obj);}}} catch (Exception e) {e.printStackTrace();}}
}

總結

Java反射和注解是Java語言中兩個強大的特性。反射允許在運行時檢查和操作類、對象、接口、字段和方法,而注解則提供了一種元數據形式,用于為代碼提供附加信息。通過結合使用反射和注解,開發者可以構建靈活、可擴展的框架和應用。

希望本文能幫助讀者深入理解Java反射和注解的使用方法和實際應用場景,從而在實際開發中更加高效地利用這些特性。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/901331.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/901331.shtml
英文地址,請注明出處:http://en.pswp.cn/news/901331.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

JavaWeb遇到的問題匯總

問題一&#xff1a;&#xff08;鍵值對最后一項沒有逗號&#xff09; 在JSON字符串轉自定義對象和自定義對象轉JSON字符串時&#xff1a; 如圖所示&#xff1a;若忘記刪除鍵值對的最后一項沒有逗號時&#xff0c;則下一句轉換不會生效&#xff0c;應該刪除最后一項的逗號。 解…

模板引擎語法-變量

模板引擎語法-變量 文章目錄 模板引擎語法-變量&#xff08;一&#xff09;在Django框架模板中使用變量的代碼實例&#xff08;二&#xff09;在Django框架模板中使用變量對象屬性的代碼實例&#xff08;三&#xff09;在Django框架模板中使用變量顯示列表 &#xff08;一&…

AUTO-RAG: AUTONOMOUS RETRIEVAL-AUGMENTED GENERATION FOR LARGE LANGUAGE MODELS

Auto-RAG&#xff1a;用于大型語言模型的自主檢索增強生成 單位&#xff1a;中科院計算所 代碼&#xff1a; https://github.com/ictnlp/Auto-RAG 擬解決問題&#xff1a;通過手動構建規則或者few-shot prompting產生的額外推理開銷。 貢獻&#xff1a;提出一種以LLM決策為中…

Python 基礎語法匯總

Python 語法 │ ├── 基本結構 │ ├── 語句&#xff08;Statements&#xff09; │ │ ├── 表達式語句&#xff08;如賦值、算術運算&#xff09; │ │ ├── 控制流語句&#xff08;if, for, while&#xff09; │ │ ├── 定義語句&#xff08;def…

一文詳解ffmpeg環境搭建:Ubuntu系統ffmpeg配置nvidia硬件加速

在Ubuntu系統下安裝FFmpeg有多種方式,其中最常用的是通過apt-get命令和源碼編譯安裝。本文將分別介紹這兩種方式,并提供安裝過程。 一、apt-get安裝 使用apt-get命令安裝FFmpeg是最簡單快捷的方式,只需要在終端中輸入以下命令即可: # 更新軟件包列表 sudo apt-get updat…

Android 14 、15動態申請讀寫權限實現 (Java)

在 Android 14、15 中&#xff0c;Google 進一步優化了存儲權限系統&#xff0c;特別是寫權限的管理。以下是完整的 Java 實現方案&#xff1a; 1. AndroidManifest.xml 聲明權限 <!-- Android 14 存儲權限 --> <uses-permission android:name"android.permiss…

小剛說C語言刷題——第23講 字符數組

前面&#xff0c;我們學習了一維數組和二維數組的概念。今天我們學習一種特殊的數組&#xff0c;字符數組。 1.字符數組的概念 字符數組就是指元素類型為字符的數組。字符數組是用來存放字符序列或者字符串的。 2.字符數組的定義及語法 char ch[5]; 3.字符數組的初始化及賦…

用AI生成系統架構圖

DeepSeek+Drawio+SVG繪制架構圖-找到一種真正可行實用的方法和思路 1、使用DeepSeek生成SVG文件,導入drawio工具的方法 ?? 問題根源分析 錯誤現象: ? 導入時報錯包含 data:image/SVG;base64 和 %20 等 URL 編碼字符 ? 代碼被錯誤轉換為 Base64 格式(適用于網頁嵌入,但…

免費干凈!付費軟件的平替款!

今天給大家分享一款超棒的電腦錄屏軟件&#xff0c;簡直不要太好用&#xff01;它的界面特別干凈&#xff0c;沒有一點兒廣告&#xff0c;看起來特別清爽。 電腦錄屏 無廣告的錄屏軟件 這個軟件超方便&#xff0c;根本不用安裝&#xff0c;打開就能直接用。 它功能也很強大&am…

【XCP實戰】AUTOSAR架構下XCP從0到1開發配置實踐

目錄 前言 正文 1.CAN功能開發 1.1 DBC的制作及導入 1.2 CanTrcv模塊配置 1.3 Can Controller模塊配置 1.4 CanIf模塊配置 2.XCP模塊集成配置配置 2.1.XCP模塊配置 2.2.XCP模塊的Task Mapping 2.3.XCP模塊的初始化 3.在鏈接文件中定義標定段 4.編寫標定相關的測試…

Vitis: 使用自定義IP時 Makefile錯誤 導致編譯報錯

參考文章: 【小梅哥FPGA】 Vitis開發中自定義IP的Makefile路徑問題解決方案 Vitis IDE自定義IP Makefile錯誤&#xff08;arm-xilinx-eabi-gcc.exe: error: *.c: Invalid argument&#xff09;解決方法 Vitis 使用自定義IP時: Makefile 文件里的語句是需要修改的&#xff0c;…

Python中NumPy的統計運算

在數據分析和科學計算領域&#xff0c;Python憑借其豐富的庫生態系統成為首選工具之一&#xff0c;而NumPy作為Python數值計算的核心庫&#xff0c;憑借其高效的數組操作和強大的統計運算功能&#xff0c;廣泛應用于機器學習、信號處理、統計分析等場景。本文將系統介紹NumPy在…

C語言程序環境和預處理詳解

本章重點&#xff1a; 程序的翻譯環境 程序的執行環境 詳解&#xff1a;C語言程序的編譯鏈接 預定義符號介紹 預處理指令 #define 宏和函數的對比 預處理操作符#和##的介紹 命令定義 預處理指令 #include 預處理指令 #undef 條件編譯 程序的翻譯環境和執行環…

智能工廠調度系統設計方案研究報告

一、系統架構設計 1.1 物理部署架構 設備層&#xff1a;部署大量搭載多傳感器陣列的 AGV 智能循跡車&#xff0c;這些傳感器包括激光雷達、視覺相機、超聲波傳感器等&#xff0c;用于感知周圍環境信息&#xff0c;實現自主導航與避障功能&#xff1b;在每個工序節點處設置 RF…

全新突破 | 更全面 · 更安全 · 更靈活

xFile 高可用存儲網關 2.0 重磅推出&#xff0c;新增多空間隔離功能從根源上防止數據沖突&#xff0c;保障各業務數據的安全性與獨立性。同時支持 NFS、CIFS、FTP 等多種主流文件協議&#xff0c;無需繁瑣的數據拷貝轉換&#xff0c;即可與現有系統無縫對接&#xff0c;降低集成…

C# js 判斷table中tr否存在相同的值

html 中如&#xff1a; 實現&#xff1a;table數據表格中&#xff0c;點擊刪除按鈕時&#xff0c;驗證相同子訂單號條數是否大于1&#xff0c;大于允許刪除。保證數據表格中只有唯一的一條子訂單號數據。 <table style"width: 100%; background-color: #fff;" ce…

操作系統基礎:07 我們的任務

課程回顧與后續規劃 上節課我們探討了操作系統的歷史。了解歷史能讓我們明智&#xff0c;從操作系統的發展歷程中&#xff0c;我們總結出兩個核心的里程碑式圖像&#xff1a;多進程&#xff08;多任務切換&#xff09;圖像和文件操作圖像 。Unix和Windows等系統的成功&#xf…

16.【.NET 8 實戰--孢子記賬--從單體到微服務--轉向微服務】--單體轉微服務--微服務的部署與運維

部署與運維是微服務架構成功實施的關鍵環節。一個良好的部署與運維體系能夠保障微服務的高可用性、可擴展性和可靠性。在這一階段&#xff0c;重點包括微服務的容器化與編排、API 網關的實現以及日志與監控體系的建設。 一、容器化與編排 1.1 使用 Docker 容器化微服務 容器…

MCP基礎學習計劃詳細總結

MCP基礎學習計劃詳細總結 1.MCP概述與基礎 ? MCP&#xff08;Model Context Protocol&#xff09;&#xff1a;由Anthropic公司于2024年11月推出&#xff0c;旨在實現大型語言模型&#xff08;LLM&#xff09;與外部數據源和工具的無縫集成。 ? 核心功能&#xff1a; ? 資…

NoSQL入門指南:Redis與MongoDB的Java實戰

一、為什么需要NoSQL&#xff1f; 在傳統SQL數據庫中&#xff0c;數據必須嚴格遵循預定義的表結構&#xff0c;就像把所有物品整齊擺放在固定尺寸的貨架上。而NoSQL&#xff08;Not Only SQL&#xff09;數據庫則像一個靈活的儲物間&#xff0c;允許存儲各種類型的數據&#x…