博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java 多线程踩过的坑
阅读量:5749 次
发布时间:2019-06-18

本文共 2334 字,大约阅读时间需要 7 分钟。

多线程踩坑记录:

1、多线程切记不可以同时操作同一个原子数据。解释:存在一个条数据库A数据,不可以在2个或2个以上的线程中同时操作A数据。会引发重复操作。
2、多线程操作方法不要加synchronized同步关键字,这失去了多线程的意义。解释:会是多线程按照同步线程执行。
3、调用第三方接口时尽量不要使用多线程。解释:因为你不知道第三方接口是否针对高并发作了处理。如果第三方接口没有针对高并发作处理,自己写的多线程逻辑也没有处理好,会导致重复操作成功。后果很难处理。
总结:
作为一只菜鸟遇到过的问题。给自己提醒下。

处理一批数据的多线程方法:

使用同步线程获取批量数据,在逻辑上将这批数据分成不同部分,每一部分使用多线程处理。这样可以避免多个线程同时操作统一个数据。

多线程的实例synchronized对比:
线程执行方法:

import threads.TaskRunnable;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;public class ThreadsMain {    public static void main(String[] args) {        //创建线程池对象  参数5,代表有5个线程的线程池        ExecutorService service = Executors.newFixedThreadPool(5);        //创建Runnable线程任务对象        TaskRunnable task = new TaskRunnable();        //从线程池中获取线程对象        service.submit(task);        System.out.println("----------------------");        //再获取一个线程对象        service.submit(task);        //关闭线程池        service.shutdown();    }}

 

带有synchronized的执行方法:

public class TaskRunnable implements Runnable{    @Override    public synchronized void run() {        for (int i = 0; i < 10; i++) {            try {                Thread.sleep(1000);            } catch (InterruptedException e) {                e.printStackTrace();            }            System.out.println("自定义线程任务在执行"+i);        }    }}

 

执行结果:

----------------------

自定义线程任务在执行0
自定义线程任务在执行1
自定义线程任务在执行2
自定义线程任务在执行3
自定义线程任务在执行4
自定义线程任务在执行5
自定义线程任务在执行6
自定义线程任务在执行7
自定义线程任务在执行8
自定义线程任务在执行9
自定义线程任务在执行0
自定义线程任务在执行1
自定义线程任务在执行2
自定义线程任务在执行3
自定义线程任务在执行4
自定义线程任务在执行5
自定义线程任务在执行6
自定义线程任务在执行7
自定义线程任务在执行8
自定义线程任务在执行9

Process finished with exit code 0

没有synchronized的执行方法:

public class TaskRunnable implements Runnable{    @Override    public  void run() {        for (int i = 0; i < 10; i++) {            try {                Thread.sleep(1000);            } catch (InterruptedException e) {                e.printStackTrace();            }            System.out.println("自定义线程任务在执行"+i);        }    }}

 

执行结果:

 

----------------------

自定义线程任务在执行0
自定义线程任务在执行0
自定义线程任务在执行1
自定义线程任务在执行1
自定义线程任务在执行2
自定义线程任务在执行2
自定义线程任务在执行3
自定义线程任务在执行3
自定义线程任务在执行4
自定义线程任务在执行4
自定义线程任务在执行5
自定义线程任务在执行5
自定义线程任务在执行6
自定义线程任务在执行6
自定义线程任务在执行7
自定义线程任务在执行7
自定义线程任务在执行8
自定义线程任务在执行8
自定义线程任务在执行9
自定义线程任务在执行9

 

Process finished with exit code 0

 

对比结论:

加入synchronized执行结果会跟同步方法相似。就失去了多线程的意义

 

转载于:https://www.cnblogs.com/gynbk/p/10861077.html

你可能感兴趣的文章
linux释放内存的方法
查看>>
基于 Android NDK 的学习之旅----- C调用Java
查看>>
Google 或强制 OEM 预装 20 款应用,给你一个不Root的理由
查看>>
我的友情链接
查看>>
双边过滤器(Bilateral filter)
查看>>
Android图形显示系统——下层显示4:图层合成上(合成原理与3D合成)
查看>>
Windows 10 技术预览
查看>>
Tomcat http跳转https
查看>>
一个自动布署.net网站的bat批处理实例
查看>>
tomcat 安装
查看>>
AIX:物理卷及有关概念
查看>>
我的友情链接
查看>>
Centos6.6安装选包及基础场景说明
查看>>
《从零开始学Swift》学习笔记(Day 61)——Core Foundation框架之内存管理
查看>>
java基础面试题-1
查看>>
深克隆与序列化效率的比较
查看>>
lamp+nginx代理+discuz+wordpress+phpmyadmin搭建一
查看>>
nagios监控使用139邮箱报警
查看>>
Windows Phone 7 中各种Task解说(启动器与选择器)
查看>>
罗森伯格助力2011年中国智能建筑技术发展应用论坛哈尔滨站
查看>>