一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java多線程事務管理的實現

Java多線程事務管理的實現

2021-10-08 01:17Acelin_H''''s Blog Java教程

本文主要介紹了Java多線程事務管理的實現,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧

今天要討論的是“Java實現多線程單條數據事務管理”,在此之前,順便回顧一下實現多線程的幾種方式

實現多線程的三種方式

一、繼承Thread類

第一種方法是繼承Thread類,重寫run()方法

?
1
2
3
4
5
public class TestThread extends Thread {
  public void run() {
   System.out.println("繼承Thread類,重寫run方法");
  }
}

使用時,new一個實例,執行start()方法

?
1
2
3
4
TestThread testThread1 = new TestThread(); // 新建狀態
TestThread testThread2 = new TestThread(); // 新建狀態
testThread1.start(); // 就緒狀態
testThread2.start(); // 就緒狀態

何時執行取決于cpu調度

二、實現Runnable接口

因為Java“單繼承、多實現”的特性,當我們已經繼承了一個類的時候,則無法再繼承Thread類,此時可以通過實現Runnable接口的方式,實現run()方法

?
1
2
3
4
5
public class TestThread extends FatherClass implements Runnable {
  public void run() {
   System.out.println("實現Runnable接口的方式,實現run方法");
  }
}

Thread類也是實現Runnable接口

使用時,需要首先實例化一個Thread,并傳入自己的TestThread實例

?
1
2
3
TestThread testThread = new TestThread();
Thread thread = new Thread(testThread);
thread.start();

三、實現Callable和Future接口

該方法區別于前兩種的特點是:能夠獲得線程處理的結果。因此該方式適用于需要對線程的結果進行處理的場景

?
1
2
3
4
5
6
7
8
9
10
11
12
class TestCallable implements Callable<Integer> {
 
    @Override
    public Integer call() {
        int sum = 0;
        for (int i = 0; i < 100; i++) {
            System.out.println(Thread.currentThread().getName() + " " + i);
            sum += i;
        }
        return sum;
    }
}

使用時,先創建TestCallable對象,然后使用FutureTask來包裝MyCallable對象,再將FutureTask對象作為Thread對象的target創建新的線程,最后thread執行start()方法,線程進入就緒狀態

?
1
2
3
4
Callable<Integer> testCallable = new TestCallable();                    // 創建TestCallable對象
FutureTask<Integer> futureTask = new FutureTask<Integer>(testCallable); // 使用FutureTask來包裝MyCallable對象
Thread thread = new Thread(futureTask);                                 // FutureTask對象作為Thread對象的target創建新的線程
thread.start();

多線程單條數據事務管理

我們有時會遇到這樣的場景:要對大批量的數據進行更新或插入操作,需要開啟多線程來提高效率,又希望每個線程在的處理一批數據時,能夠對其中每條數據進行處理的時,做到出錯時實現單條數據回滾,而不是所有數回滾(所有數據回滾后續討論)。先看代碼:

根據以上多線程知識,我們先定義一個業務線程類如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
public class TestTranstionalThread extends Thread {
 
    private List<BalBankDictEntity> balBankDictEntities;
 
    public TestTranstionalThread( List<BalBankDictEntity> balBankDictEntities){
        this.balBankDictEntities = balBankDictEntities;
 
    }
 
    @Override
    public void run() {
 
        log.info("線程{}開始",Thread.currentThread().getName());
 
        for (BalBankDictEntity balBankDictEntity : balBankDictEntities) {
 
            try{
                collBillDao.insOneBank(balBankDictEntity);
            }catch (BusiException e){
                log.error("{}回滾",balBankDictEntity.getBankId());
            }
 
        }
 
        log.info("線程{}結束",Thread.currentThread().getName());
    }
}

insOneBank()方法如下,注意的@Transactional注解的事務隔離等級為:REQUIRES_NEW,創建一個新的事務。

?
1
2
3
4
5
6
7
8
9
10
@Transactional(propagation = Propagation.REQUIRES_NEW)
public void insOneBank(BalBankDictEntity balBankDictEntity){
 
    balBankDictMapper.insert(balBankDictEntity);
 
    /* 模擬發生異常,拋出異常,實現將已插入數據回滾 */
    if (Integer.parseInt(balBankDictEntity.getBankId().substring(2)) % 100 == 0){
        throw new BusiException("test");
    }
}

開啟多線程進行業務處理,注意加上@Transactional注解

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
@Transactional
public void testTransactional(){
 
    /* 模擬測試數據 */
    List<BalBankDictEntity> balBankDictEntities = new ArrayList<>();
    for (int i = 0 ; i < 100000 ; i ++){
        BalBankDictEntity balBankDictEntity = new BalBankDictEntity();
        balBankDictEntity.setBankCode("BK" + i);
        balBankDictEntity.setBankId("ID" + i + "");
        balBankDictEntity.setBankName("N" + i + "N");
        balBankDictEntities.add(balBankDictEntity);
    }
 
    int totalNum = balBankDictEntities.size();
    log.info("totalNum" + totalNum);
 
    /* 分10個線程處理 */
    ExecutorService fixedThreadPool = Executors.newFixedThreadPool(10);
    int dealNum = totalNum % 10 == 0 ? totalNum / 10 : totalNum / 10 + 1; // 計算每個線程處理的數量
 
    for (int i = 1; i <= 10 ; i++ ){
        List<BalBankDictEntity> balBankDictEntityList = splitDataList(balBankDictEntities,dealNum,10,i);  // 切割數據集實現數據隔離
 
        TestTranstionalThread testTranstional = new TestTranstionalThread(balBankDictEntityList);
        fixedThreadPool.execute(testTranstional);
 
    }
}

最終實現多個線程并發插入數據,有異常的數據的單獨回滾,不影響整體

到此這篇關于Java多線程事務管理的實現的文章就介紹到這了,更多相關Java多線程事務管理內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/acelin/p/15003247.html

延伸 · 閱讀

精彩推薦
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7472021-02-04
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
主站蜘蛛池模板: 学校女性奴sm训练调教 | 热久久99精品这里有精品 | 欧美精品国产第一区二区 | 午夜在线观看免费完整直播网 | 果冻传媒和91制片厂网站软件 | 日本福利片国产午夜久久 | 好爽轻点太大了太深了 | 无人区免费一二三四乱码 | 青青成人福利国产在线视频 | 校草太大了h | 国产精品香蕉夜间视频免费播放 | 99热精品在线观看 | 超碰成人在线播放 | 丰满艳妇亲伦视频 | 国产精品永久免费10000 | 色综合天天综合 | 88av免费观看 | 好男人资源大全免费观看 | 免费在线观看小视频 | 娇小XXXXX第一次出血 | 精品国语对白精品自拍视 | 日本不卡视频免费 | 饭冈加奈子乳喷cead144 | gay中国| 欧美性一区二区三区 | 免看一级一片一在线看 | 女人狂吮男人命根gif视频 | 门房秦大爷最新章节阅读 | 拔插拔插.com| 免费欧美日韩 | 久久精品国产亚洲AV热无遮挡 | 亚洲 日韩 在线 国产 视频 | 风间由美在线播放 | 国产精品成人网红女主播 | 国产精品露脸国语对白99 | 国产99在线观看 | 国产无套在线播放 | 大胆国模一区二区三区伊人 | 青青成人福利国产在线视频 | 精品女同同性视频很黄很色 | 青青草原影院 |