高并发编程

本文深入探讨了Java高并发编程的基础概念,包括并发与高并发的区别、Java内存模型(JMM)及其核心组件如堆和栈的特点。此外,还详细解释了JMM中的八种基本同步操作,并分析了高并发编程的优势与潜在风险。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

高并发编程

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

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

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

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

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

Java内存模型同步八种操作

锁定(Lock)

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

解锁(unlock)

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

read(读取)

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

load(载入)

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

use(使用)

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

assign(赋值)

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

store(存储)

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

write(写入)

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

并发的优势与风险

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

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

总结

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

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

Java并发的优势与风险

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值