第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

是否可以在 lambda 表達(dá)式中迭代數(shù)組?(java)

是否可以在 lambda 表達(dá)式中迭代數(shù)組?(java)

FFIVE 2023-12-13 10:12:44
我需要ForkJoinTask為每個(gè)部門(mén)創(chuàng)建一個(gè)新的部門(mén),并且不知道如何到達(dá)數(shù)組中的下一個(gè)位置。有人能幫我嗎?protected static double parManyTaskArraySum(final double[] input, final int numTasks) {        double sum = 0;        // ToDo: Start Calculation with help of ForkJoinPool        ForkJoinPool fjp = new ForkJoinPool(numTasks);        fjp.execute(() -> {            sum+=( 1 / input[???] ); //the problem is here        });        return sum;    }例外:從 lambda 表達(dá)式引用的局部變量必須是最終的或?qū)嶋H上最終的
查看完整描述

1 回答

?
米脂

TA貢獻(xiàn)1836條經(jīng)驗(yàn) 獲得超3個(gè)贊

您正在Runnable向您的ForkJoinPool. 因此,您無(wú)法使用所需的數(shù)組塊對(duì)其進(jìn)行參數(shù)化。


您實(shí)際上應(yīng)該定義一個(gè)擴(kuò)展類(lèi)RecursiveTask<Double>,其構(gòu)造函數(shù)將數(shù)組塊作為參數(shù),并決定是對(duì)整個(gè)數(shù)組進(jìn)行操作還是在數(shù)組太大時(shí)進(jìn)行分叉。


然后使用invoke您的方法ForkJoinPool來(lái)獲取最終計(jì)算的結(jié)果,通過(guò)向其傳遞一個(gè)RecursiveTask<Double>采用整個(gè)數(shù)組的新實(shí)例(任務(wù)將根據(jù)您的標(biāo)準(zhǔn)決定是一次性完成所有操作還是分叉,例如,數(shù)組元素的一半轉(zhuǎn)移到另一個(gè)任務(wù)并稍后加入)。


請(qǐng)注意,這里有些混亂。


事實(shí)上,如果您不需要利用 fork/join 框架而只想異步執(zhí)行操作,那么有很多方法可以在不使用ForkJoinPool.


例如:


Callable<Double> call  = () -> {return Arrays.stream(input).sum();};

Future<Double> future =  Executors.newSingleThreadExecutor().submit(call);

// when you're ready

Double sum = future.get();


查看完整回答
反對(duì) 回復(fù) 2023-12-13
  • 1 回答
  • 0 關(guān)注
  • 169 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)