java多线程问题之同步器CyclicBarrier
来源:互联网 发布:淘宝刷単单子app 编辑:程序博客网 时间:2024/05/08 20:19
还是上次的oracle迁移到mysql的遗留问题,当我在查看数据的时候,发现两个库数据量不一致。最后证实了我的看法,我修改代码时将10个进程简成1个单线程来完成了。所以数据量会少那么多呢。
原因很简单当时就是这个函数CyclicBarrier,当时不理解具体的意思:
if (sessionParameter.getSourceThreadNum() > 1) {System.out.println("多线程运行");CyclicBarrier barrier = new CyclicBarrier(sessionParameter.getSourceThreadNum() + 2);for (int i = 0; i <= sessionParameter.getSourceThreadNum(); i++) {dataSyncThread dataSync = new dataSyncThread(barrier, i,sDataSource, tDataSource, sessionParameter);dataSync.start();}long start = System.currentTimeMillis();barrier.await();barrier.await();long end = System.currentTimeMillis();在实际应用中,有时候需要多个线程同时工作以完成同一件事情,而且在完成过程中,往往会等待其他线程都完成某一阶段后再执行,等所有线程都到达某一个阶段后再统一执行。 其中,的barrier就是相当于一个阻断,障碍器,CyclicBarrier最重要的属性就是参与者个数,另外最要方法是await()。当所有线程都调用了await()后,就表示这些线程都可以继续执行,否则就会等待。只有达到CyclicBarrier(int number)中number的数量,才能使程序中的10个进程同步进行互不干扰。
- java多线程问题之同步器CyclicBarrier
- java同步器之CyclicBarrier
- 黑马程序员-Java多线程同步器CyclicBarrier
- java CyclicBarrier 同步器
- JAVA 同步器CountDownLatch CyclicBarrier
- Java并发同步器--CyclicBarrier
- java多线程编程——同步器CyclicBarrier(二)
- Java多线程编程之同步器
- Java多线程之CyclicBarrier
- Java多线程之CyclicBarrier
- JAVA多线程之CyclicBarrier
- Java多线程之CyclicBarrier
- Java多线程之CyclicBarrier
- Java多线程之----CyclicBarrier
- Java 多线程之CyclicBarrier
- 同步器CyclicBarrier
- CyclicBarrier(同步器)
- JAVA多线程之(CyclicBarrier)
- iphone 检测屏幕触摸事件
- 能让用户心情好的UI设计
- zImgage uImage Image区别
- java 反射 , 判断Class是否是某个类的子类或父类
- origin 安装
- java多线程问题之同步器CyclicBarrier
- <!DocType Html>
- 用python实现文件转移,到另一个目录中
- jacob使用入门(转)
- tar 两个小技巧
- 为weblogic配置maven插件
- js encodeURIComponent 之php解码
- ror and redmine
- Word/Excel/PDF文件转换成HTML整理