摘要:我們的引擎使用預定義的分隔符來連接日志中的信息,并存儲在一個中。在抽象類中定義帶參數(shù)的構造函數(shù)在抽象類中定義動態(tài)屬性的第一種方法是定義一個參數(shù)的構造函數(shù)。
翻譯:瘋狂的技術宅
原文:http://programmergate.com/def...
本文首發(fā)微信公眾號:充實的腦洞
Abstract關鍵字通常被用于類和方法,用來把某些行為的實現(xiàn)委托給子類。由于Java不支持抽象屬性,如果你試圖將類屬性標記為抽象,將會得到一個編譯時錯誤。
在本教程中,我們將介紹兩種定義抽象屬性的方法,這些抽象屬性可以由子類進行設置,而且不使用Abstract 關鍵字。
實用案例假設我們想要實現(xiàn)一個記錄事務的日志模塊,用來記錄特定事務的信息。我們希望這個模塊是抽象的,這樣我們可以實現(xiàn)不同的日志記錄方式,例如:記錄到文件或數(shù)據庫中。
我們的引擎使用預定義的分隔符來連接日志中的信息,并存儲在一個String中。具體應該使用哪個分隔符,這將取決于日志記錄的規(guī)則,例如可以用字符“,”對日志記錄中不同部分的信息進行分割。
因此,分隔符看起來對我們的引擎是抽象的,需要由每個日志記錄規(guī)則明確定義。
下面我提供兩種方式,來實現(xiàn)把分隔符的定義委托給子類。
在抽象類中定義帶參數(shù)的構造函數(shù)在抽象類中定義動態(tài)屬性的第一種方法是:定義一個參數(shù)的構造函數(shù)。
所以我們可以這樣實現(xiàn)這個引擎:
// TransactionManager.java public abstract class TransactionManager { private String separator; public TransactionManager(String separator) { this.separator = separator; } public abstract void writeTransaction(String result); public Transaction startTransaction() { Transaction transaction = new Transaction(System.currentTimeMillis()); return transaction; } public void endTransaction(Transaction t) { long processingTime = System.currentTimeMillis() - t.getStartTime(); StringBuilder logBuilder = new StringBuilder(); logBuilder.append(t.getStartTime()); // Notice the use of this.separator logBuilder.append(this.separator); logBuilder.append(processingTime); logBuilder.append(this.separator); logBuilder.append(t.getData()); String result = logBuilder.toString(); writeTransaction(result); } }
在抽象類中定義帶參數(shù)的構造函數(shù)時,子類將會被強制定義自己的構造函數(shù)并調用super()。 這樣我們就能強制separator屬性依賴于已使用的日志記錄機制。
注意,我們的引擎實現(xiàn)了所有日志機制共有的靜態(tài)行為:startTransaction(), endTransaction(),同時將動態(tài)行為writeTransaction()交給子類去實現(xiàn)。
現(xiàn)在,如果我們想要創(chuàng)建一個事務管理器,用它將日志內容記錄到一個文件中,那么可以這樣去定義:
public class TransactionManagerFS extends TransactionManager{ // The IDE forces you to implement constructor. public TransactionManagerFS(String separator) { super(separator); } @Override public void writeTransaction(String result) { System.out.println("The following transaction has just finished: " ); System.out.println(result); } }
接下來做一個測試,看看代碼是怎樣工作的
public static void main(String[] args) throws InterruptedException { // we pass the separator explicitly in the constructor TransactionManager transactionManager = new TransactionManagerFS(","); Transaction transaction = transactionManager.startTransaction(); transaction.setData("This is a test transaction !!"); Thread.sleep(1500); transactionManager.endTransaction(transaction); }輸出:
The following transaction has just finished: 1502179140689,1501,This is a test transaction !!通過getter方法傳遞分隔符
另外一種實現(xiàn)動態(tài)屬性的方法是:通過定義一個抽象的getter方法,該方法根據當前的日志記錄機制來檢索所需的分隔符。在我們的引擎中,當需要要使用分隔符時,可以通過調用這個getter方法得到。
接下來我們將引擎修改成這樣:
public abstract class TransactionManager { public abstract String getSeperator(); public abstract void writeTransaction(String result); public Transaction startTransaction() { Transaction transaction = new Transaction(System.currentTimeMillis()); return transaction; } public void endTransaction(Transaction t) { long processingTime = System.currentTimeMillis() - t.getStartTime(); StringBuilder logBuilder = new StringBuilder(); logBuilder.append(t.getStartTime()); // Notice the use of getSeparator() logBuilder.append(getSeperator()); logBuilder.append(processingTime); logBuilder.append(getSeperator()); logBuilder.append(t.getData()); String result = logBuilder.toString(); writeTransaction(result); } }
另外修改TransactionManagerFS如下:
public class TransactionManagerFS extends TransactionManager{ @Override public String getSeperator() { return ","; } @Override public void writeTransaction(String result) { System.out.println("The following transaction has just finished: " ); System.out.println(result); } }
然后,修改main以使用新的實現(xiàn),并確保得到正確的結果。
public static void main(String[] args) throws InterruptedException { // The separator is defined implicitly using getSeparator() method of the manager TransactionManager transactionManager = new TransactionManagerFS(); Transaction transaction = transactionManager.startTransaction(); transaction.setData("This is a test transaction !!"); Thread.sleep(1500); transactionManager.endTransaction(transaction); }輸出:
The following transaction has just finished: 1502179140689,1501,This is a test transaction !!
本文首發(fā)于公眾號:充實的腦洞 | |
---|---|
歡迎掃碼關注充實的腦洞,一個技術宅的保留地 |
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/70188.html
摘要:弄了一個持續(xù)更新的筆記,可以去看看,鏈接地址此篇文章的地址使用兩年后值得嗎基礎筆記的地址可以也可以。使用,你可以使用抽象類等功能。有關抽象類的更多信息支持,和方法,只讀屬性。 弄了一個持續(xù)更新的github筆記,可以去看看,鏈接地址:Front-End-Basics 此篇文章的地址:使用TypeScript兩年后-值得嗎? 基礎筆記的github地址:https://githu...
摘要:元素和組件實例都不表示真實元素。我希望這篇文章能夠幫助你理清這些術語參考資料翻譯成支撐實例來自于理解中方法創(chuàng)建組件的聲明式編程和命令式編程的比較對循環(huán)提示增加的研究精髓之一算法 本篇為譯文,原文出處:React Elements vs React Components vs Component Backing Instances 許多人可能聽說過 Facebook 的 React 庫,...
摘要:隨后,它出現(xiàn)在公司之后的瀏覽器,以及從微軟從起發(fā)布的所有瀏覽器上。標準的第版在年月的大會上被表決接受。第版在年月底大會上被采納。 前言 ??本系列譯文的初衷旨在希望更多人能夠了解關于JS的一些基本概念,遇到原理性的問題時多去翻翻文檔,而不是在社區(qū)無休止的重復提出某些在文檔中能夠非常方便快捷就能找到的東西。 ??精力和水平有限,所以暫時只打算嘗試翻譯前面幾章概括性的介紹,同時后面的章節(jié)大...
摘要:實現(xiàn)我們將創(chuàng)建一個抽象類,該類聲明了兩個方法以及記錄客戶端名字的屬性值。創(chuàng)建具體的類集成該抽象類。第一步創(chuàng)建抽象類第二步創(chuàng)建具體的類繼承抽象類第三步創(chuàng)建類第四步使用類通過傳遞的值來獲取或者類的對象第五步校驗輸出推薦閱讀被遺忘的設計模式 原文鏈接 譯者:smallclover Thanks for your watching 設計模式-Null Object Pattern 在Nul...
摘要:一個就像一個樂高玩具。問題是不是你小時候玩兒的那個有趣,它們不是充滿想象力的打氣筒,也不是一種樂高玩具。這是對的并不是給開發(fā)者使用的,它們是給庫作者使用的。不會超過這兩種情況。第二個是根據第一個處理函數(shù)如何運行來自動變成狀態(tài)成功或者失敗。 原文地址:http://blog.getify.com/promis... 在 Part4:擴展問題 中,我討論了如何擴展和抽象Promise是多么...
閱讀 3898·2021-11-22 13:54
閱讀 2673·2021-09-30 09:48
閱讀 2359·2021-09-28 09:36
閱讀 3110·2021-09-22 15:26
閱讀 1342·2019-08-30 15:55
閱讀 2509·2019-08-30 15:54
閱讀 1424·2019-08-30 14:17
閱讀 2340·2019-08-28 18:25