摘要:我們的引擎使用預(yù)定義的分隔符來(lái)連接日志中的信息,并存儲(chǔ)在一個(gè)中。在抽象類中定義帶參數(shù)的構(gòu)造函數(shù)在抽象類中定義動(dòng)態(tài)屬性的第一種方法是定義一個(gè)參數(shù)的構(gòu)造函數(shù)。
翻譯:瘋狂的技術(shù)宅
原文:http://programmergate.com/def...
本文首發(fā)微信公眾號(hào):充實(shí)的腦洞
Abstract關(guān)鍵字通常被用于類和方法,用來(lái)把某些行為的實(shí)現(xiàn)委托給子類。由于Java不支持抽象屬性,如果你試圖將類屬性標(biāo)記為抽象,將會(huì)得到一個(gè)編譯時(shí)錯(cuò)誤。
在本教程中,我們將介紹兩種定義抽象屬性的方法,這些抽象屬性可以由子類進(jìn)行設(shè)置,而且不使用Abstract 關(guān)鍵字。
實(shí)用案例假設(shè)我們想要實(shí)現(xiàn)一個(gè)記錄事務(wù)的日志模塊,用來(lái)記錄特定事務(wù)的信息。我們希望這個(gè)模塊是抽象的,這樣我們可以實(shí)現(xiàn)不同的日志記錄方式,例如:記錄到文件或數(shù)據(jù)庫(kù)中。
我們的引擎使用預(yù)定義的分隔符來(lái)連接日志中的信息,并存儲(chǔ)在一個(gè)String中。具體應(yīng)該使用哪個(gè)分隔符,這將取決于日志記錄的規(guī)則,例如可以用字符“,”對(duì)日志記錄中不同部分的信息進(jìn)行分割。
因此,分隔符看起來(lái)對(duì)我們的引擎是抽象的,需要由每個(gè)日志記錄規(guī)則明確定義。
下面我提供兩種方式,來(lái)實(shí)現(xiàn)把分隔符的定義委托給子類。
在抽象類中定義帶參數(shù)的構(gòu)造函數(shù)在抽象類中定義動(dòng)態(tài)屬性的第一種方法是:定義一個(gè)參數(shù)的構(gòu)造函數(shù)。
所以我們可以這樣實(shí)現(xiàn)這個(gè)引擎:
// 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ù)的構(gòu)造函數(shù)時(shí),子類將會(huì)被強(qiáng)制定義自己的構(gòu)造函數(shù)并調(diào)用super()。 這樣我們就能強(qiáng)制separator屬性依賴于已使用的日志記錄機(jī)制。
注意,我們的引擎實(shí)現(xiàn)了所有日志機(jī)制共有的靜態(tài)行為:startTransaction(), endTransaction(),同時(shí)將動(dòng)態(tài)行為writeTransaction()交給子類去實(shí)現(xiàn)。
現(xiàn)在,如果我們想要?jiǎng)?chuàng)建一個(gè)事務(wù)管理器,用它將日志內(nèi)容記錄到一個(gè)文件中,那么可以這樣去定義:
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); } }
接下來(lái)做一個(gè)測(cè)試,看看代碼是怎樣工作的
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 !!通過(guò)getter方法傳遞分隔符
另外一種實(shí)現(xiàn)動(dòng)態(tài)屬性的方法是:通過(guò)定義一個(gè)抽象的getter方法,該方法根據(jù)當(dāng)前的日志記錄機(jī)制來(lái)檢索所需的分隔符。在我們的引擎中,當(dāng)需要要使用分隔符時(shí),可以通過(guò)調(diào)用這個(gè)getter方法得到。
接下來(lái)我們將引擎修改成這樣:
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以使用新的實(shí)現(xiàn),并確保得到正確的結(jié)果。
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ā)于公眾號(hào):充實(shí)的腦洞 | |
---|---|
歡迎掃碼關(guān)注充實(shí)的腦洞,一個(gè)技術(shù)宅的保留地 |
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/70188.html
摘要:弄了一個(gè)持續(xù)更新的筆記,可以去看看,鏈接地址此篇文章的地址使用兩年后值得嗎基礎(chǔ)筆記的地址可以也可以。使用,你可以使用抽象類等功能。有關(guān)抽象類的更多信息支持,和方法,只讀屬性。 弄了一個(gè)持續(xù)更新的github筆記,可以去看看,鏈接地址:Front-End-Basics 此篇文章的地址:使用TypeScript兩年后-值得嗎? 基礎(chǔ)筆記的github地址:https://githu...
摘要:元素和組件實(shí)例都不表示真實(shí)元素。我希望這篇文章能夠幫助你理清這些術(shù)語(yǔ)參考資料翻譯成支撐實(shí)例來(lái)自于理解中方法創(chuàng)建組件的聲明式編程和命令式編程的比較對(duì)循環(huán)提示增加的研究精髓之一算法 本篇為譯文,原文出處:React Elements vs React Components vs Component Backing Instances 許多人可能聽(tīng)說(shuō)過(guò) Facebook 的 React 庫(kù),...
摘要:隨后,它出現(xiàn)在公司之后的瀏覽器,以及從微軟從起發(fā)布的所有瀏覽器上。標(biāo)準(zhǔn)的第版在年月的大會(huì)上被表決接受。第版在年月底大會(huì)上被采納。 前言 ??本系列譯文的初衷旨在希望更多人能夠了解關(guān)于JS的一些基本概念,遇到原理性的問(wèn)題時(shí)多去翻翻文檔,而不是在社區(qū)無(wú)休止的重復(fù)提出某些在文檔中能夠非常方便快捷就能找到的東西。 ??精力和水平有限,所以暫時(shí)只打算嘗試翻譯前面幾章概括性的介紹,同時(shí)后面的章節(jié)大...
摘要:實(shí)現(xiàn)我們將創(chuàng)建一個(gè)抽象類,該類聲明了兩個(gè)方法以及記錄客戶端名字的屬性值。創(chuàng)建具體的類集成該抽象類。第一步創(chuàng)建抽象類第二步創(chuàng)建具體的類繼承抽象類第三步創(chuàng)建類第四步使用類通過(guò)傳遞的值來(lái)獲取或者類的對(duì)象第五步校驗(yàn)輸出推薦閱讀被遺忘的設(shè)計(jì)模式 原文鏈接 譯者:smallclover Thanks for your watching 設(shè)計(jì)模式-Null Object Pattern 在Nul...
摘要:一個(gè)就像一個(gè)樂(lè)高玩具。問(wèn)題是不是你小時(shí)候玩兒的那個(gè)有趣,它們不是充滿想象力的打氣筒,也不是一種樂(lè)高玩具。這是對(duì)的并不是給開發(fā)者使用的,它們是給庫(kù)作者使用的。不會(huì)超過(guò)這兩種情況。第二個(gè)是根據(jù)第一個(gè)處理函數(shù)如何運(yùn)行來(lái)自動(dòng)變成狀態(tài)成功或者失敗。 原文地址:http://blog.getify.com/promis... 在 Part4:擴(kuò)展問(wèn)題 中,我討論了如何擴(kuò)展和抽象Promise是多么...
閱讀 3910·2021-11-22 13:54
閱讀 2684·2021-09-30 09:48
閱讀 2365·2021-09-28 09:36
閱讀 3121·2021-09-22 15:26
閱讀 1348·2019-08-30 15:55
閱讀 2517·2019-08-30 15:54
閱讀 1428·2019-08-30 14:17
閱讀 2346·2019-08-28 18:25