Java程序中的延遲加載功能使用
使用多個(gè)對(duì)象或者大數(shù)據(jù)結(jié)構(gòu)時(shí),一種提升其性能的方式是運(yùn)用延遲加載或賦值(來(lái)實(shí)現(xiàn))。將費(fèi)時(shí)的操作盡可能的縮短的想法,從未實(shí)現(xiàn)。我通過(guò)一些例子來(lái)說(shuō)明延遲加載技術(shù)在Java中如何運(yùn)用,給予一些指引以在其他語(yǔ)言中能更易(使用)并作為核心語(yǔ)言的一部分。
一種使用場(chǎng)景是通過(guò)JTable來(lái)展示數(shù)百個(gè)包含元數(shù)據(jù)和測(cè)量值得域?qū)ο?。初始化我們的域?qū)ο笤趦?nèi)存中能保存兩種類型的對(duì)象,即便在表格中僅顯示部分元數(shù)據(jù)。構(gòu)建該表格將花費(fèi)數(shù)秒鐘的時(shí)間,(但)我們可以接受再次展示數(shù)百項(xiàng)(數(shù)據(jù))。在做了一些分析過(guò)后,我們改進(jìn)了我們的實(shí)現(xiàn),看起來(lái)像這樣:
public class DomainObject {
private final DataParser parser;
private final Map<String, String> header = new HashMap<>();
private final List<Data> data = new ArrayList<>();
public DomainObject(DataParser aParser) {
parser = aParser;
}
public String getHeaderField(String name) {
// Here we lazily parse and fill the header map
if (header.isEmpty()) {
header.addAll(parser.header());
}
return header.get(name);
}
public Iterable<Data> getMeasurementValues() {
// again lazy-load and parse the data
if (data.isEmpty()) {
data.addAll(parser.measurements());
}
return data;
}
}
這種改進(jìn)改善了顯示時(shí)間的條目和顯著提高了我們處理大數(shù)據(jù)項(xiàng)的(能力)。所有的數(shù)據(jù)載入僅在有人想查看測(cè)量的具體細(xì)節(jié)和雙擊某條目時(shí)才會(huì)發(fā)生。
一種java拆箱后得到延遲賦值在條件語(yǔ)句的情況下
// lazy and fast because the expensive operation will only execute when needed
if (aCondition() && expensiveOperation()) { ... }
// slow order (still lazy evaluated!)
if (expensiveOperation() && aCondition()) { ... }
持久層框架像Hibernate時(shí)常默認(rèn)延遲加載是因?yàn)樵谕ǔG闆r下數(shù)據(jù)庫(kù)訪問(wèn)并且數(shù)據(jù)傳送代價(jià)相當(dāng)高昂。
大多數(shù)語(yǔ)言功能是基于環(huán)繞延遲賦值的情況下這種理論上的功能如同第一個(gè)類所有成員最大程度上隔離降低副作用對(duì)延遲的影響。Scala混合了面向?qū)ο笳Z(yǔ)言功能并引進(jìn)延遲關(guān)鍵字簡(jiǎn)化了java樣式,延遲初始代碼就像下面這樣
public class DomainObject(parser: DataParser) {
// evaluated on first access
private lazy val header = { parser.header() }
def getHeaderField(name : String) : String = {
header.get(name).getOrElse("")
}
// evaluated on first access
lazy val measurementValues : Iterable[Data] = {
parser.measurements()
}
}
結(jié)論
延遲加載不是新的革命性技術(shù)但當(dāng)處理大數(shù)據(jù)或放慢資源卻是一個(gè)非常有用的工具。在這些很多情況下你能使用它提升性能或使用者親身經(jīng)歷使用它。
它可以降低實(shí)現(xiàn)代碼的成本如果語(yǔ)言支持不是很好(像java)和其它一些情況的下應(yīng)用就要在預(yù)編譯預(yù)處理情況下感受更多的響應(yīng)。
相關(guān)文章
java啟動(dòng)jar包修改JVM默認(rèn)內(nèi)存問(wèn)題
這篇文章主要介紹了java啟動(dòng)jar包修改JVM默認(rèn)內(nèi)存問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
Spring Boot使用Spring的異步線程池的實(shí)現(xiàn)
這篇文章主要介紹了Spring Boot使用Spring的異步線程池的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
springboot集成JWT實(shí)現(xiàn)身份認(rèn)證(權(quán)鑒)的方法步驟
本文主要介紹了springboot集成JWT實(shí)現(xiàn)身份認(rèn)證(權(quán)鑒)的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
在Java中使用ModelMapper簡(jiǎn)化Shapefile屬性轉(zhuǎn)JavaBean實(shí)戰(zhàn)過(guò)程
本文介紹了在Java中使用ModelMapper庫(kù)簡(jiǎn)化Shapefile屬性轉(zhuǎn)JavaBean的過(guò)程,對(duì)比了原始的set方法和構(gòu)造方法,展示了如何使用ModelMapper進(jìn)行動(dòng)態(tài)屬性映射,從而減少手動(dòng)編寫轉(zhuǎn)換代碼的工作量,通過(guò)示例代碼,展示了如何使用GeoTools讀取Shapefile屬性并將其轉(zhuǎn)換為JavaBean對(duì)象2025-02-02

