高并发编程

高并发编程

并发:多个线程操作相同的资源,保证线程安全,合理使用资源。

高并发:服务能同时处理很多请求,提高程序性能。

Java内存模型(Java Memory Model,JMM)

堆:可以动态的生成内存大小,垃圾收集器会自动回收,存储速度慢。

栈:存储块,仅次于计数器,存在的大小必须固定。

Java内存模型同步八种操作

锁定(Lock)

作为与主内存的变量,把一个变量标识为一条线程独占状态。

解锁(unlock)

作用于主内存的变量,把一个处于锁定状态的变量释放出来,释放后的变量菜可以被其他线程锁定。

read(读取)

作用于主内存的变量,把一个变量值从主内存传输到线程的工作内存中,以便以后的load动作使用。

load(载入)

作用于工作内存的变量,它把read操作从主内存中得到的变量值放入工作内存的变量副本中。

use(使用)

作用于工作内存的变量,把工作内存中的一个变量值传递给执行引擎。

assign(赋值)

作用于工作内存的变量,它把一个从执行引擎接收到的值赋给工作内存的变量。

store(存储)

作用于工作内存的变量,把工作内存中的一个变量的值传送到主内存中,以便随后的wirte的操作。

write(写入)

作用于主内存的变量,它把store操作从工作内存中的一个变量的值传送到主内存的变量中。

并发的优势与风险

优势:速度,设计,资源利用。

风险:安全性,活跃性,性能。

总结

CPU多级缓存:缓存一致性,乱序执行优化

java内存模型:JMM规定,抽象结构,同步八种操作及规则。

Java并发的优势与风险

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值