深入浅出java多线程(总结)

一. 基本概念介绍

1. 线程是系统中最小的执行单元。

2. 同一进程中有多个线程。

3. 线程共享进程的资源。

4. 线程的交互

4.1. 互斥

2.2. 同步


二. java线程初体验

2.1 java语言对线程的支持

Thread类和Runnable接口,它们共有的方法是run()。


三. java线程的正确停止

线程停止的错误方法是stop()和interrupt()。

正确的是设置退出旗标。

四. 线程交互

争用条件:当多个线程同时共享访问同一数据(内存区域)时,每个线程都尝试操作该数据,从而导致数据被破坏,这种现象称为争用条件。

解决:互斥&同步

互斥的实现:synchronized(intrinsic lock)

同步的实现:wait()/notify()/notifyAll()(object对象的成员函数)

     互斥:是指某一资源同时只允许一个访问者对其进行访问,具有唯一性和排它性。但互斥无法限制访问者对资源的访问顺序,即访问是无序的。
   同步:是指在互斥的基础上(大多数情况),通过其它机制实现访问者对资源的有序访问。在大多数情况下,同步已经实现了互斥,特别是所有写入资源的情况必定是互斥的。少数情况是指可以允许多个访问者同时访问资源。

五. 进阶展望

如何扩展Java并发的知识:

JVM描述了Java线程如何通过内存进行交互

happen-before

synchronized,volatile&final

Locks&Condition:

Java锁机制和等待条件的高层实现

java.util.concurrent.locks

线程安全性:

原子性和可见性

java.util.concurrent.atomic

synchronized&volatile

DeadLocks

多线程常用的交互模型:

Producer-Consumer模型

Read-Write Lock模型

Future模型

Worker Thread模型

java5中并发编程工具:

都位于java.util.concurrent包之下

线程池ExecutorService

Callable&Future

BlockingQueue


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值