第一個(gè)線程處理這10W個(gè)客戶,第二個(gè)線程處理發(fā)數(shù)據(jù)。遍歷客戶很快,發(fā)數(shù)據(jù)耗時(shí)間耗性能。所以為了避免10W個(gè)客戶同時(shí)發(fā)數(shù)據(jù)導(dǎo)致宕機(jī)(極端現(xiàn)象)??梢栽谛阅茉试S的情況下,設(shè)定一個(gè)線程池處理發(fā)數(shù)據(jù)的邏輯操作。
創(chuàng)新互聯(lián)憑借在網(wǎng)站建設(shè)、網(wǎng)站推廣領(lǐng)域領(lǐng)先的技術(shù)能力和多年的行業(yè)經(jīng)驗(yàn),為客戶提供超值的營銷型網(wǎng)站建設(shè)服務(wù),我們始終認(rèn)為:好的營銷型網(wǎng)站就是好的業(yè)務(wù)員。我們已成功為企業(yè)單位、個(gè)人等客戶提供了成都網(wǎng)站制作、做網(wǎng)站服務(wù),以良好的商業(yè)信譽(yù),完善的服務(wù)及深厚的技術(shù)力量處于同行領(lǐng)先地位。
不能在同一個(gè)方法內(nèi)并發(fā)運(yùn)行兩個(gè)for循環(huán),因?yàn)樵诜椒w內(nèi)是順序執(zhí)行的,前一個(gè)for不跳出,后一個(gè)for是不能執(zhí)行的。如果想要并發(fā)執(zhí)行,需要使用Thread類,詳情可以去看關(guān)于java線程的知識(shí)。
到這里通用的性能優(yōu)化思路差不多了,我們了解一些 Java語言特定的優(yōu)化方案。在一個(gè)語句中拼接字符串使用 + 等下這個(gè)問題不是和 5沖突了嗎?其實(shí)不是的。
1、定長線程池的大小最好根據(jù)系統(tǒng)資源進(jìn)行設(shè)置。
2、newFixedThreadPool:創(chuàng)建的是定長的線程池,可以控制線程最大并發(fā)數(shù),超出的線程會(huì)在線程隊(duì)列中等待,使用的是無界隊(duì)列,核心線程數(shù)和最大線程數(shù)一樣,當(dāng)線程池中的線程沒有任務(wù)時(shí)候立刻銷毀,使用默認(rèn)線程工廠。
3、corePoolSize:核心線程數(shù) 核心線程會(huì)一直存活,及時(shí)沒有任務(wù)需要執(zhí)行。當(dāng)線程數(shù)小于核心線程數(shù)時(shí),即使有線程空閑,線程池也會(huì)優(yōu)先創(chuàng)建新線程處理。設(shè)置allowCoreThreadTimeout=true(默認(rèn)false)時(shí),核心線程會(huì)超時(shí)關(guān)閉。
4、大范圍打斷點(diǎn)的方法,確定不到問題位置。采取逐步刪代碼的方法,找到原因。newFixedThreadPool 創(chuàng)建一個(gè)定長線程池,可控制線程最大并發(fā)數(shù),超出的線程會(huì)在隊(duì)列中等待。線程池沒有關(guān)閉,導(dǎo)致spark-submit在等線程池結(jié)束。
5、多線程可以通過繼承或?qū)崿F(xiàn)接口的方式創(chuàng)建。 Thread 類是 JDK 中定義的用于控制線程對(duì)象的類,該類中封裝了線程執(zhí)行體 run() 方法。需要強(qiáng)調(diào)的一點(diǎn)是,線程執(zhí)行先后與創(chuàng)建順序無關(guān)。
6、ThreadPoolExecutor類是Java中的一個(gè)內(nèi)置類,它可以用于創(chuàng)建和管理線程池。這個(gè)類提供了很多有用的方法和屬性,例如可以指定線程池的大小、最大線程數(shù)、線程空閑時(shí)間等參數(shù)。
將這個(gè)變量設(shè)置成靜態(tài)的。將這個(gè)變量弄成如同單例模式一樣的。不管是多少個(gè)線程。指向的都是這同一個(gè)變量。網(wǎng)站流量的統(tǒng)計(jì)就是用的一個(gè)全局變量。
Java 多線程代碼中創(chuàng)建了10個(gè)線程,而每個(gè)線程都持有this對(duì)象的對(duì)象鎖,這不能實(shí)現(xiàn)線程的同步。
三個(gè)線程共享count, 但count++不是原子操作,包括count與比較sum時(shí)候 也是, 會(huì)導(dǎo)致出現(xiàn)多線程問題。