多线程踩坑记录:
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执行结果会跟同步方法相似。就失去了多线程的意义

java 多线程踩过的坑的更多相关文章

  1. java多线程 ThreadPoolExecutor 策略的坑

    无论是使用jdk的线程池ThreadPoolExecutor 还是spring的线程池ThreadPoolTaskExecutor 都会使用到一个阻塞队列来进行存储线程任务. 当线程不够用时,则将后续 ...

  2. linux下多线程踩过的坑(不定更新)

    1,多线程下整个进程的退出 <<APUE>>关于进程环境一章中指出了进程退出的8个条件: ... (4)最后一个线程从启动例程中返回 (5)最后一个线程调用pthread_ex ...

  3. 踩过无数坑实现的哈夫曼压缩(JAVA)

    最近可能又是闲着没事干了,就想做点东西,想着还没用JAVA弄过数据结构,之前搞过算法,就试着写写哈夫曼压缩了. 本以为半天就能写出来,结果,踩了无数坑,花了整整两天时间!!orz...不过这次踩坑,算 ...

  4. Java日期处理易踩的十个坑

    前言 整理了Java日期处理的十个坑,希望对大家有帮助. 一.用Calendar设置时间的坑 反例: Calendar c = Calendar.getInstance(); c.set(Calend ...

  5. Java面试中遇到的坑【填坑篇】

    看到大家对上篇<Java面试中遇到的坑>一文表现出强力的关注度,说明大家确实在面试中遇到了类似的难题.大家在文章留言处积极留言探讨面试中遇到的问题,其中几位同学还提出了自己的见解,我感到非 ...

  6. 第一章 Java多线程技能

    1.初步了解"进程"."线程"."多线程" 说到多线程,大多都会联系到"进程"和"线程".那么这两者 ...

  7. Java多线程编程详解

    转自:http://programming.iteye.com/blog/158568 线程的同步 由于同一进程的多个线程共享同一片存储空间,在带来方便的同时,也带来了访问冲突这个严重的问题.Ja ...

  8. "开发路上踩过的坑要一个个填起来————持续更新······(7月30日)"

    欢迎转载,请注明出处! https://gii16.github.io/learnmore/2016/07/29/problem.html 踩过的坑及解决方案记录在此篇博文中! 个人理解,如有偏颇,欢 ...

  9. 50个Java多线程面试题

    不管你是新程序员还是老手,你一定在面试中遇到过有关线程的问题.Java 语言一个重要的特点就是内置了对并发的支持,让 Java 大受企业和程序员的欢迎.大多数待遇丰厚的 Java 开发职位都要求开发者 ...

随机推荐

  1. atitit.bsh BeanShell 的动态脚本使用java

    atitit.bsh BeanShell 的动态脚本使用java 1.1. BeanShell是一个小巧免费的JAVA源码解释器 ,支持对象式的脚本语言特性,亦可嵌入到JAVA源代码中. 亦可嵌入到J ...

  2. JavaScript的join()

    JavaScript join() 方法 JavaScript Array 对象 定义和用法 join() 方法用于把数组中的所有元素放入一个字符串. 元素是通过指定的分隔符进行分隔的. 语法 arr ...

  3. synchronized 锁优化

    synchronized 在jdk 1.7之前是重量级锁,独占锁,非公平锁.jdk1.7之后,synchronized引入了 偏向锁,自旋锁,轻量级锁,重量级锁 自旋锁 当线程在获取锁的时候,如果发现 ...

  4. [转载]Axis2 and CXF的比较

    在Celtix 和XFire 宣布合并的同年,另一个著名开源Web 服务框架Axis 的后继者Axis2 也诞生了.Axis2 并非Axis 的2.0 版,而是完全重写了Axis 的新项目.作为功能和 ...

  5. HDFS源码分析数据块复制选取复制源节点

    数据块的复制当然需要一个源数据节点,从其上拷贝数据块至目标数据节点.那么数据块复制是如何选取复制源节点的呢?本文我们将针对这一问题进行研究. 在BlockManager中,chooseSourceDa ...

  6. apache重定向无效

    这个问题让我纠结了蛮久啊,因为之前一直不注意SEO,网站带www和不带www的一级域名都被收录了,而且不知道为什么不带www的一级域名被收录比www还多,这可不是我的初衷!这次吸取教训了,以后再开站不 ...

  7. ubuntu安装源

    1.编辑sources.list文件 sudo vi /etc/apt/sources.list 添加以下安装源 #台湾源 deb http://tw.archive.ubuntu.com/ubunt ...

  8. java Collection-Map 之 TreeMap

    TreeMap 内部定义了一个类  static final class Entry<K,V> implements Map.Entry<K,V>,(自平衡红黑二叉树)作为数据 ...

  9. eclipse 连接 hadoop集群

    1 网上找插件 或者 自己编译 放到eclipse plugin里面 2 重启eclipse 配置MapReduceLocation 通吃端口为9001 9000 看你自己的配置 3 新建mapRed ...

  10. XML5632 : Only one root element is allowed. Line: 1, Column 1

    奇葩啊, 最后查出来是因为有一个svg文件名对不上...