Java并发--内存结构图及线程安全

内存结构图

内存-> (开辟的数组) -> (方法区,堆,栈,程序计数器,本地方法栈)

img

:几乎所有的对象实例都在这里分配内存。堆中每个对象的头信息都标属着他属于哪个类。

方法区它用于存储已被虚拟机加载的类型信息、常量、静态变量、即时编译器编译后的代码缓存等数据

的区域很小,只有1M,特点是存取速度很快,所以在stack中存放的都是快速执行的任务,基本数据类型的数据,和对象的引用(reference),方法的拷贝运行。只有处于栈顶的方法才处于运行状态,其他的属于就绪状态。

本地方法栈:栈中方法拷贝运行时,因为底层时c语言的方法,所以需要本地方法栈,来翻译方法,使之成为操作系统本身的内核方法,对接驱动。

每个线程启动的时候,都会创建一个PC(Program Counter,程序计数器)寄存器。PC寄存器里保存有当前正在执行的JVM指令的地址

小例子:

w,e的指向确实改变了,但是没有影响到x1,x2。

什么是Class常量池?

  • 我们写的每一个Java类被编译后,就会形成一份Class文件Class文件除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池表(Constant Pool Table),用于存放编译期生成的各种字面量与符号引用

  • 每一个Class文件中都有一个Class常量池

被编译后的类就会进入Class常量池

IO操作

IO操作,就是将数据写入内存或从内存输出的过程,也指应用程序和外部设备之间的数据传递。

常见IO流操作,一般指内存与磁盘间的输入输出流操作。

final关键字

1.对象构造函数内有final域,必须先用构造函数构造对象,再把对象赋给其他引用 2.如果对象有final域,必须先读对象的引用,再读final域。

这两个规则的目的是保证:在对象引用为任意线程可见之前,对象的final域已经被正确初始化过了,而普通域就不具有这个保障。

请看下面的Java代码,它定义了一个类Person,有两个域:name和age。name是一个final域,age是一个非final域。然后,它创建了一个Person对象,并在另一个线程中读取它的域。

c
lass Person {final String name; // final域int age; // 非final域
public Person(String name, int age) {this.name = name; // 写final域this.age = age; // 写非final域
}
}
​
public class Test {static Person person;public static void main(String[] args) throws InterruptedException {Thread t1 = new Thread(new Runnable() {@Overridepublic void run() {person = new Person("Alice", 20); // 把对象引用赋值给person}});Thread t2 = new Thread(new Runnable() {@Overridepublic void run() {if (person != null) { // 读对象引用System.out.println(person.name); // 读final域System.out.println(person.age); // 读非final域}}});t1.start();t2.start();t1.join();t2.join();
}
}

根据final的重排序规则,线程t2在读取person.name时,一定能看到正确的值Alice,因为写final域和赋值对象引用之间不能重排序。但是,线程t2在读取person.age时,可能看到的不是正确的值20,而是0,因为写非final域和赋值对象引用之间可以重排序。这就是final和非final域的区别

使用多线程可能会带来的问题

并发编程的目的就是为了能提高程序的执行效率提高程序运行速度,但是并发编程并不总是能提高程序运行速度的,而且并发编程可能会遇到很多问题,比如:内存泄漏、死锁、线程不安全等等。

如何理解线程安全不安全?

线程安全和不安全是在多线程环境下对于同一份数据的访问是否能够保证其正确性和一致性的描述。

  • 线程安全指的是在多线程环境下,对于同一份数据,不管有多少个线程同时访问,都能保证这份数据的正确性和一致性。

  • 线程不安全则表示在多线程环境下,对于同一份数据,多个线程同时访问时可能会导致数据混乱、错误或者丢失。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/620551.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

绿色地狱steam叫什么 绿色地狱steam怎么搜

绿色地狱steam叫什么 绿色地狱steam怎么搜 《绿色地狱》是一款以亚马逊雨林为背景的开放世界生存模拟游戏。玩家们扮演一名被困在丛林中的冒险者,玩家在游戏内需要学习采集资源、建造庇护所、狩猎和烹饪食物,同时要面对丛林中的危险和挑战,…

华为数通方向HCIP-DataCom H12-821题库(多选题:321-340)

第321题 关于OSPF的命令描述,不正确的是: A、stub区域和totally stub区域配置了no-summary参数 B、OSPFv2和OSPF v3配置接口命令的区别是OSPF V2可以使用network命令,而OSPFv3直接 C、在接口上使能stubrouter命令用来配置次路由器为stub路由器,stub路由器可以与非stub路由 …

用可视化大屏汇报,领导只说:很漂亮。要注意!可能是狗屁不通。

确保汇报的可视化大屏能够有效传达信息和数据,除了外观漂亮,还需要注意以下几点: 内容准确性:确保所展示的数据和信息准确无误,避免出现错误或误导。 重点突出:通过合适的图表、图形和动画效果&#xff0c…

Linux服务器磁盘扩容后,但是宝塔面板没有即使生效,以解决~!

前景描述:我是100G的磁盘,扩容到200G. 第一步查看服务器的当前磁盘 df -h 显示 99G,已经扩容了,但是服务器还没有更新信息。 第二步安装插件: yum install -y cloud-utils-growpart 第三步扩展分区: …

SD-WAN提升企业网络体验

在现代企业中,网络体验已成为提升工作效率与业务质量的关键因素。SD-WAN技术的出现,以其独特的优势,为企业提供了优化网络连接、加速数据传输、提升服务质量和应用访问体验,以及增强网络稳定性的解决方案。接下来,我们…

2024 MathorCup C 题 物流网络分拣中心货量预测及人员排班

一、问题重述 电商物流网络在订单履约中由多个环节组成,图1是一个简化的物流网络示意图。其中,分拣中心作为网络的中间环节,需要将包裹按照不同流向进行分拣并发往下一个场地,最终使包裹到达消费者手中。分拣中心管理效率的提升&…

OpenHarmony实战开发-如何解决阻塞事件冒泡。

介绍 本示例主要介绍在点击事件中,子组件enabled属性设置为false的时候,如何解决点击子组件模块区域会触发父组件的点击事件问题;以及触摸事件中当子组件触发触摸事件的时候,父组件如果设置触摸事件的话,如何解决父组…

Java 设计模式系列:模板方法模式

简介 模板方法模式是一种行为型设计模式,它定义一个操作中的算法骨架,将一些步骤推迟到子类中。模板方法模式使得子类可以不改变一个算法的结构,即可重定义该算法的某些特定步骤。 在模板方法模式中,抽象类中定义了一系列基本操…

UE5 C++ 创建3DWidgete 血条 再造成伤害

一.创建 二.UI里声明变量 创建类 public:UPROPERTY(EditAnywhere,BlueprintReadWrite,Category "MyWidget")float CurrentHealth 100.0f;UPROPERTY(EditAnywhere,BlueprintReadWrite,Category "MyWidget"…

利用taobao.item_search API接口,多样搜索类型满足你的购物需求

在信息化时代的今天,网络购物已经成为人们日常生活的重要组成部分。淘宝作为中国最大的电商平台之一,每天都有数以亿计的商品信息在平台上流转。对于消费者而言,如何在海量商品中快速准确地找到心仪的产品,成为了一个重要的课题。…

Vue3学习05 一些API

Vue3-API 其它 API【shallowRef 与 shallowReactive 】shallowRefshallowReactive总结 【readonly 与 shallowReadonly】readonlyshallowReadonly 【toRaw 与 markRaw】toRawmarkRaw 【customRef】 Vue3新组件【Teleport】【Suspense】【全局API转移到应用对象】【其他】 其它 …

软考127-上午题-【软件工程】-McCabe度量法

一、McCabe度量法 1-1、定义 McCabe 度量法是通过定义环路复杂度,建立程序复杂性的度量。 它基于一个程序模块的程序图中环路的个数。计算有向图G的环路复杂性的公式为: V(G) m - n 2 闭合区域 1 其中V(G)是有向图 G 中的环路个数,m 是…