首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

多线程的共享变量的内存不可见性

同步值之synchronized和volatile的区别 相同点:   synchronized 和 volatile都能用来同步共享变量 不同点:   1. volatile是轻量级的同步策略, 可以修饰基本类型的变量,如int, synchronized是重量级的同步策略,基于对象的同步锁   2. volatile不具备互斥性, 一个线程访问共享变量 , 其他线程也可以访问共享变量     synchronized是互斥锁, 具备互斥性, 在被锁的代码块上只能有一个线程访问共享变量   3. volatile不能保证变量的原子性, 即一组对共享变量的操作不具备事务(要么全部完成,要么全部不完成) 如 i++/i-- 即一个线程在进行一组操作中还没完成时, 其他线程也能进入这组操作对共享变量进行修改 而 synchronized则能保证一组对共享变量操作的原子性, 即这组操作全部完成,才能进行下一轮操作 即在被锁的代码块中只能允许一个线程去执行这组操作, 其他需要执行这组操作的线程会进入阻塞状态,等待其完成 总结:

02

【地铁上的面试题】--基础部分--操作系统--进程与线程

进程与线程是操作系统中重要的概念,用于实现并发执行和资源管理。它们在计算机系统中扮演着不同的角色,并具有各自的特点。 进程是程序在执行过程中的一个实体,是资源分配的基本单位。一个进程可以包含多个线程,每个线程共享进程的资源,包括内存、文件句柄、打开的文件等。每个进程都有自己的地址空间和独立的执行状态,通过操作系统进行管理和调度。进程之间相互独立,彼此隔离,拥有自己的地址空间,需要通过进程间通信来实现数据共享和协作。 线程是进程中的一个执行单元,是 CPU 调度的基本单位。一个进程可以包含多个线程,这些线程可以并发执行,共享进程的资源。线程之间共享同一进程的地址空间,可以直接访问进程的全局变量和堆内存,减少了进程间通信的开销。由于线程之间共享资源,所以需要采取同步机制来避免数据竞争和冲突。 进程与线程的基本特点如下:

03
领券