Java 多線程傳值的四種方法
其實(shí)大家都知道多線程傳值有三種方式:
1:通過(guò)構(gòu)造方法傳遞數(shù)據(jù)2:通過(guò)變量和方法傳遞數(shù)據(jù)3:通過(guò)回調(diào)函數(shù)傳遞數(shù)據(jù)
那么博主有個(gè)非常變態(tài)的需求,所以找出了第四種實(shí)現(xiàn)方式,先看效果圖:

動(dòng)態(tài)Cron4j調(diào)度器,我曾經(jīng)發(fā)過(guò)類(lèi)似的文章,可以去搜索一下.
點(diǎn)擊執(zhí)行走下邊的代碼,然后根據(jù)類(lèi)名反編譯
public static void executeCron4j(String packageClass){ try { Object taskObj = classNewInstance(packageClass); /** 只接受Runnable的定時(shí)器 **/ if (taskObj instanceof Runnable) {Runnable task = (Runnable)taskObj;Thread t1 = new Thread(new Runnable() { public void run() { task.run(); }});t1.start(); } } catch (Exception e) { e.printStackTrace(); } }
線程類(lèi):(注意:線程要和上邊設(shè)置的包名一致)
public void run() { TCron4j cron4j = TCron4j.dao.findByClass(this.getClass().getName());//根據(jù)包名反編譯,然后查詢(xún)數(shù)據(jù)庫(kù)}
現(xiàn)在博主的需求是:有可能在同一個(gè)線程類(lèi)執(zhí)行不一樣的程序。
上邊兩個(gè)紅框中的cron4j調(diào)度器使用的是一個(gè),根據(jù)參數(shù)不同來(lái)執(zhí)行的。如果我點(diǎn)擊后邊的手動(dòng)執(zhí)行一次,按照我上邊給出的java代碼是無(wú)法實(shí)現(xiàn)的。
看下邊的新的代碼:
public static void executeCron4j(String packageClass){ try { Object taskObj = classNewInstance(packageClass); /** 只接受Runnable的定時(shí)器 **/ if (taskObj instanceof Runnable) {Runnable task = (Runnable)taskObj;Thread t1 = new Thread(new Runnable() { public void run() { task.run(); }});t1.setName('uuid');//這個(gè)是線程的名字t1.start(); } } catch (Exception e) { e.printStackTrace(); } }
從上邊的代碼可以看出,第四種傳值方式是通過(guò)設(shè)置線程的名字來(lái)操作的。
這個(gè)名字你可以傳一個(gè)id,然后去數(shù)據(jù)庫(kù)查詢(xún)更多的參數(shù)。
public void run() { TCron4j cron4j = TCron4j.dao.findByUUID(Thread.currentThread().getName());//根據(jù)線程名字查詢(xún)數(shù)據(jù)庫(kù)}
這種方式完美的解決了博主的難題。現(xiàn)在共享出來(lái)分享給大家!!!
以上就是Java 多線程傳值的四種方法的詳細(xì)內(nèi)容,更多關(guān)于Java 多線程傳值的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. IntelliJ IDEA安裝插件的方法步驟2. php模擬實(shí)現(xiàn)斗地主發(fā)牌3. 理解PHP5中static和const關(guān)鍵字4. spring acegi security 1.0.0 發(fā)布5. vue 使用localstorage實(shí)現(xiàn)面包屑的操作6. MyBatis中的JdbcType映射使用詳解7. Vuex localStorage的具體使用8. Python random庫(kù)使用方法及異常處理方案9. .Net Core使用Coravel實(shí)現(xiàn)任務(wù)調(diào)度的完整步驟10. Vue封裝一個(gè)TodoList的案例與瀏覽器本地緩存的應(yīng)用實(shí)現(xiàn)

網(wǎng)公網(wǎng)安備