Java中的惰性評(píng)估是什么?具體是怎么使用的?下面,根據(jù)這兩個(gè)問(wèn)題,文章將會(huì)給出相應(yīng)的答案。想要了解的小伙伴,可以閱讀下面分享的文章內(nèi)容。
1、說(shuō)明
惰性評(píng)估是將表達(dá)式的評(píng)估延遲到需要時(shí)才進(jìn)行的過(guò)程。Java是嚴(yán)格的立即賦值評(píng)估。
可以使用lambda表達(dá)式和高階函數(shù)將其重寫為延遲評(píng)估的版本。
2、實(shí)例
public class LazySample {
public static void main(String[] args) {
//這是一個(gè)lambda表達(dá)式,表現(xiàn)為閉包
UnaryOperator<Integer> add = t -> {
System.out.println("executing add");
return t + t;
};
//這是一個(gè)lambda表達(dá)式,表現(xiàn)為閉包
UnaryOperator<Integer> multiply = t -> {
System.out.println("executing multiply");
return t * t;
};
//傳遞Lambda閉包而不是普通函數(shù)
System.out.println(addOrMultiply(true, add, multiply, 4));
System.out.println(addOrMultiply(false, add, multiply, 4));
}
//這是一個(gè)高階函數(shù)
static <T, R> R addOrMultiply(
boolean add, Function<T, R> onAdd,
Function<T, R> onMultiply, T t
) {
// Java的?會(huì)懶惰計(jì)算表達(dá)式,因此僅執(zhí)行所需的方法
return (add ? onAdd.apply(t) : onMultiply.apply(t));
}
}
實(shí)例擴(kuò)展:
public class SingleLock<V> implements Lazy<V> {
private Callable<V> codeBlock;
private V value;
public SingleLock(Callable<V> codeBlock) {
this.codeBlock = codeBlock;
}
@Override
public synchronized V get() {
if (value == null) {
setValue();
}
return value;
}
private void setValue() {
try {
value = codeBlock.call();
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}
到此這篇關(guān)于java懶惰評(píng)估以及具體實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)java懶惰評(píng)估的內(nèi)容,請(qǐng)搜索W3Cschool以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持!