多线程并发编程

1.进程与线程

进程:内存运行的一个应用程序,系统运行的基本单位。

线程:进程的一个执行单元,一个进程有多个线程。

区别:每个进程有独立内存空间,线程之间的堆空间和方法区共享;线程栈空间和程序计数器是独立的。

2.并发与并行

并发Concurrency:并发是指在一段时间内宏观上多个程序同时运行。

并行Parallel:并行指的是同一个时刻,多个任务确实真的在同时运行。

3.上下文切换:线程执行位置的记录(程序计数器)与加载过程。

4.线程一生:New创建->Runnable可运行->Terminated终止->Blocked阻塞->Waiting等待            ->TimedWaitng超时等待

5.sleep()方法没有释放锁 暂停线程;wait()方法释放了锁 线程间交互/通信

6.创建线程性能很差:线程安全+互斥锁;start()-start0-JVM-Thread-OS-参数run()方法

7.线程安全问题:多个线程共享变量 Synchronized ReentrenLock

原子性;有序性(指令重排-同步代码块);可见性(JMM内存模型-定义线程和主内存之间关系)

happens-before:如果一个操作的执行结果需要对另一个操作可见。

a.程序顺序规则      b.锁规则      c.Volatile变量规则       d.传递性规则

8.Synchronized原理:加锁

Monitor 管程:理共享变量及对共享变量操作的过程,让这个过程并发执行/等待队列

Java所有对象都可以作为锁-对象头-每个对象都有一个Monitor

无锁->偏向锁(只有一个线程访问,帮忙消除锁)

->轻量级锁(只有两个线程交替竞争,CAS乐观锁自旋)

->重量级锁(操作系统互斥锁)

9.Volatile原理:不加锁

内存屏障:禁止指令重排 实现内存可见性-写操作(store);读操作(load)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值