多线程听课笔记

1.进程与线程

1.1进程

定义:

  1. 程序(任务)的执行过程——是一个动态的概念
  2. 持有资源(共享内存,共享文件)和线程

1.2线程

定义:

  1. 线程是系统中最小的执行单元
  2. 同一进程中有多个线程
  3. 线程共享进程的资源

线程的交互(通信):

  1. 互斥
  2. 同步

2.Java中的线程

实现方法:

java.lang包——

  1. 继承class Thread
  2. 实现interface Runnable

关键:run()方法

线程停止:

  使用结束标志;1.不要使用stop方法。2.不要使用interrupt方法。

  使线程正常退出,而不会戛然而止。

3.线程的交互

  争用条件(Race Condition)

互斥:synchronized

同步:wait/notifyAll

 

建议拓展:

1.Java Memory Mode

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

  happens-before

  synchronized,volatile&final

2.Locks&Condition

  Java锁机制的高级实现

  java.util.concurrent.locks

3.线程安全性

  原子性与可见性

  java.util.concurrent.atomic

  synchronized&volatile

  DeadLocks

4.多线程编程常用的交互模型

  Producer-Consumer模型

  Read-Write Lock模型

  Future模型

  Worker Thread模型

5.Java5中并发变成工具

  java.util.concurrent

  线程池ExecutorService

  Callable&Future

  BlockingQueue

转载于:https://www.cnblogs.com/cheerflower/p/6662930.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值