如何用型別變數引用目前型別
你能用型別變數引用目前型別嗎?
假設你是建立一個函數以傳回目前類型的實例。有沒有辦法讓類型變數 T 引用精確的子類型(因此 T 應該引用 B 類別中的 B)?
class A { <t extends a> void foo(); } class B extends A { @Override T foo(); }</t>
解決方案
為了建立 StriplingWarrior 的回應,需要以下設計(分層流暢建構器 API的公式):
首先,一個抽象基類(或介面),用於建立用於檢索擴展類的實例的運行時類型的契約:
/** * @param <self> The runtime type of the implementer. */ abstract class SelfTyped<self extends selftyped>> { /** * @return This instance. */ abstract SELF self(); }</self></self>
中間擴展類必須是抽象的並維護遞歸類型參數SELF:
public abstract class MyBaseClass<self extends mybaseclass>> extends SelfTyped<self> { MyBaseClass() { } public SELF baseMethod() { //logic return self(); } }</self></self>
進一步派生的類別可以遵循相同的圖案。但是,如果不使用原始類型或通配符(這會破壞該模式的目的),這些類別都不能直接用作變數類型。例如(如果 MyClass 不是抽象的):
//wrong: raw type warning MyBaseClass mbc = new MyBaseClass().baseMethod(); //wrong: type argument is not within the bounds of SELF MyBaseClass<mybaseclass> mbc2 = new MyBaseClass<mybaseclass>().baseMethod(); //wrong: no way to correctly declare the type, as its parameter is recursive! MyBaseClass<mybaseclass>> mbc3 = new MyBaseClass<mybaseclass>>().baseMethod();</mybaseclass></mybaseclass></mybaseclass></mybaseclass>
這就是為什麼這些類別被稱為“中間類別”,以及為什麼它們都應該被聲明為抽象的。 「葉」類別需要完成循環並使用該模式,該模式解析繼承的類型參數 SELF 及其類型並實作 self()。為了防止破壞契約,它們也應該被標記為final:
public final class MyLeafClass extends MyBaseClass<myleafclass> { @Override MyLeafClass self() { return this; } public MyLeafClass leafMethod() { //logic return self(); //could also just return this } }</myleafclass>
使用這樣的類別使得模式可用:
MyLeafClass mlc = new MyLeafClass().baseMethod().leafMethod(); AnotherLeafClass alc = new AnotherLeafClass().baseMethod().anotherLeafMethod();
這樣做的主要優點是方法呼叫可以在類別層次結構中上下鏈接,同時保持相同的特定返回類型。
以上是如何在 Java 中使用類型變數引用目前型別?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

類加載器通過統一的類文件格式、動態加載、雙親委派模型和平台無關的字節碼,確保Java程序在不同平台上的一致性和兼容性,實現平台獨立性。

Java編譯器生成的代碼是平台無關的,但最終執行的代碼是平台特定的。 1.Java源代碼編譯成平台無關的字節碼。 2.JVM將字節碼轉換為特定平台的機器碼,確保跨平台運行但性能可能不同。

多線程在現代編程中重要,因為它能提高程序的響應性和資源利用率,並處理複雜的並發任務。 JVM通過線程映射、調度機制和同步鎖機制,在不同操作系統上確保多線程的一致性和高效性。

Java的平台獨立性是指編寫的代碼可以在任何安裝了JVM的平台上運行,無需修改。 1)Java源代碼編譯成字節碼,2)字節碼由JVM解釋執行,3)JVM提供內存管理和垃圾回收功能,確保程序在不同操作系統上運行。

Javaapplicationscanindeedencounterplatform-specificissuesdespitetheJVM'sabstraction.Reasonsinclude:1)Nativecodeandlibraries,2)Operatingsystemdifferences,3)JVMimplementationvariations,and4)Hardwaredependencies.Tomitigatethese,developersshould:1)Conduc

云计算显著提升了Java的平台独立性。1)Java代码编译为字节码,由JVM在不同操作系统上执行,确保跨平台运行。2)使用Docker和Kubernetes部署Java应用,提高可移植性和可扩展性。

Java'splatformindependenceallowsdeveloperstowritecodeonceandrunitonanydeviceorOSwithaJVM.Thisisachievedthroughcompilingtobytecode,whichtheJVMinterpretsorcompilesatruntime.ThisfeaturehassignificantlyboostedJava'sadoptionduetocross-platformdeployment,s

容器化技術如Docker增強而非替代Java的平台獨立性。 1)確保跨環境的一致性,2)管理依賴性,包括特定JVM版本,3)簡化部署過程,使Java應用更具適應性和易管理性。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。