美文网首页
Java并发总结

Java并发总结

作者: Lcap | 来源:发表于2019-10-18 16:09 被阅读0次

一、安全性

多线程访问某个类时,不管运行时环境采用何种调度方式,这些线程如何交替执行,主调用程序都无需任何额外同步,该类均能表现出正确行为,则称该类为线程安全的。

  • 原子性
  • 加锁机制
    • 内置锁 synchronized
    • 显式锁 Lock
    • 线程安全的容器 ConcurrentHashMapConcurrentSkipListMapCollections.synchronized*()方法等。

二、活跃性

  • 死锁
    多个线程,由于需要获取对方持有的资源,因而无止境的等待的窘境。
    --> 避免:
    1)显式锁,并设置超时时间。
    2)根据hash值顺序加锁,hash相同时设置Tie-Breaking锁
    3)开放调用(Open Call),调用方法不持有锁,仅在方法内部使用同步块保护共享资源。(“快进快出”)
    --> 诊断:使用线程转储存jstack分析。

  • 饥饿
    无法获得相应的资源,一直在等待中。
    1)优先级与操作系统强相关,尽量不修改线程优先级;
    2)不要在长时间等待资源时持有锁。

  • 活锁
    多个相互协作的线程对彼此响应从而修改各自状态,不断尝试执行,并不停的失败。
    --> 分别等待一段随机时间后重试。

三、性能与可伸缩性

性能与可伸缩性均会带来复杂性;先保证正确,若有性能问题再优化。
性能(关注速度) - 减少计算代价:缓存、算法优化;
可伸缩(关注吞吐量) - 并行: 锁分解、锁分段;

  • 优化考虑:
    1.效果;2.有效条件;3. 发生频率;4. 是否可复用;5. 产生代价;

  • 减少锁竞争的办法:

    1. 减少锁持有时间(“快进快出”);
    2. 降低锁粒度(拆分为多个非交叉竞争的锁);
    3. 非独占锁(读写锁)、原子变量、非阻塞锁(CAS);

相关文章

  • java多线程并发

    关于Java并发编程的总结和思考java并发大总结Java并发的四种风格优先使用TimeUnit类中的sleep(...

  • 万字长文:关于Synchronized锁升级,你该了解这些!

    面试终败“高并发”,25天苦心钻研,居然整出一份并发宝典? 秋招JAVA面试总结:Java+并发+Spring+M...

  • Nginx 踩坑 413 Request Entity Too

    Java高级面试攻略:消息+缓存+高并发+高可用+架构+分布式+微服务 秋招JAVA面试总结:Java+并发+Sp...

  • Effective java总结

    总结 effecttive java 注意的地方简单概括下。并发部分没有java并发编程实战全。就不写在这了 JD...

  • Java并发教程

    Java并发教程 Java并发概述Java并发环境设置Java并发主要操作Java并发性线程间通信Java并发同步...

  • 后端架构师技术图谱(三)-并发、锁、设计模式(二)

    并发 多线程 《40个Java多线程问题总结》 线程安全 《Java并发编程——线程安全及解决机制简介》 一致性、...

  • Java并发总结

    JMM内存抽象 JMM定义了线程和主内存之间的抽象关系:线程之间的共享变量存储在主内存中,每个线程都有一个私有的本...

  • Java 并发总结

    1.synchronized 重量级锁,jdk1.6后做了优化,也不一定是重量级了。 2.锁有4种状态,无锁,偏向...

  • Java并发总结

    Java并发总结 1.多线程的优点 资源利用率更好 程序在某些情况下更简单 程序响应更快 2.创建线程 1.实现R...

  • java并发总结

    设计一个线程安全的程序尤为重要,尤其是在高并发环境下。对一些的概念进行记录,如果不对的地方还望指正。 概念 vol...

网友评论

      本文标题:Java并发总结

      本文链接:https://www.haomeiwen.com/subject/qnhmmctx.html