首页
学习
活动
专区
圈层
工具
发布

为什么局部变量是线程安全的?

最近看到一个问题,说是 局部变量是线程安全的?一开始我是拒绝的,因为在我的意识里如果多个线程同时访问一个方法就一定为导致数据竞争,从而导致数据混乱。...于是我就开始验证我的结论是对的(在线打脸现场emm…) 为什么局部变量是线程安全的?...look at the next line↓: 每个线程执行时将会把局部变量放在各自栈帧的工作内存中,线程间不共享,故不存在线程安全问题。...如何理解上面这句话: 结论 局部变量(方法内部的私有变量)是线程安全的,代码中的num这个私有变量是线程安全的,原因是在new HasSelfPrevateNum()这个类的时候它只会为类中的属性成员变量开辟空间...,而方法只在方法区开辟一个内存空间并且只存一份是共用的代码段(变量在堆区,引用在栈区),而方法中的私有变量不会先开辟出内存空间,而是等调用时在对应调用线程中为方法中的变量申请空间,所以有几个线程调用则每个线程就会在自己的线程空间的栈为局部变量申请几个引用同时在堆中为变量再申请对应的空间

1.1K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ThreadLocal共享线程局部变量和线程同步机制的区别

    ThreadLocal是解决线程安全问题一个很好的思路,它通过为每个线程提供一个独立的变量副本解决了变量并发访问的冲突问题。...对于多线程资源共享的问题,同步机制采用了“以时间换空间”的方式,而ThreadLocal采用了“以空间换时间”的方式。...前者仅提供一份变量,让不同的线程排队访问,而后者为每一个线程都提供了一份变量,因此可以同时访问而互不影响。 ThreadLocal并不能替代同步机制,两者面向的问题领域不同。         ...1:同步机制是为了同步多个线程对相同资源的并发访问,是为了多个线程之间进行通信的有效方式;          2:而threadLocal是隔离多个线程的数据共享,从根本上就不在多个线程之间共享变量,...这样当然不需要对多个线程进行同步了。

    91730

    深入理解多级缓存必备知识--线程局部变量

    使用thread_local设计支持多线程的分级存储的cache 如何利用线程局部变量 实现一个分级存储的缓存结构 提示: 为了帮助 通过角色扮演 对话方式 小义:新手,初学者,候选人 老王:充当面试官...(TLS)区域的段寄存器(Linux/glibc 下)。...如果声明局部变量,无法线程内共享。 老王:thread_local 有什么缺点呢,如何优化 小义: 转换问题:thread_local 读写其他线程不可见,如果想可见呢怎么办?...、锁) 可移植性 跨平台(标准 C++ 支持,如 Windows、Linux、macOS) 主要在类 Unix 系统(Linux、macOS)原生支持;Windows 需第三方库(如 pthreads-win32...通过 thread_local 关键字声明线程局部变量 使用 pthread_key_create()、pthread_setspecific() 等函数管理 线程取消 协作式(需通过共享标志位或原子变量控制线程退出

    19310

    深入理解多级缓存必备知识--线程局部变量

    使用thread_local设计支持多线程的分级存储的cache如何利用线程局部变量 实现一个分级存储的缓存结构 提示: 为了帮助 通过角色扮演 对话方式小义:新手,初学者,候选人 老王:充当面试官,项目经理老王...(TLS)区域的段寄存器(Linux/glibc 下)。...如果声明局部变量,无法线程内共享。老王:thread_local 有什么缺点呢,如何优化小义:转换问题:thread_local 读写其他线程不可见,如果想可见呢怎么办?...、锁)​​可移植性​​跨平台(标准 C++ 支持,如 Windows、Linux、macOS)主要在类 Unix 系统(Linux、macOS)原生支持;Windows 需第三方库(如 pthreads-win32...thread_local 关键字声明线程局部变量使用 pthread_key_create()、pthread_setspecific() 等函数管理​​线程取消​​协作式(需通过共享标志位或原子变量控制线程退出

    19400

    【Linux】多线程——线程概念|Linux下进程与线程|线程控制

    所以在Linux中,可以把进程和线程做一个统一,CPU看到的task_struct称为轻量级进程 在Linux中,什么是线程:CPU调度的基本单位!...所以Linux中,没有给Linux"线程"去专门设计对应的数据结构!而是直接复用PCB!用PCB来表示Linux内部的“线程”!...也就是说,Linux内核中有没有真正意义的线程,严格上来说是没有的,Linux是用进程PCB来模拟线程的,是一种完全属于自己的一套线程方案。...并且在函数内定义的变量都是局部变量具有临时性,在多线程情况下也没有问题。...,在Linux中,如果要实现多线程,必定要使用pthread库,如何看待C++11中的多线程:C++11的多线程,在Linux环境中本质就是对pthread库的封装。

    1.6K30

    【Linux】线程

    线程(Thread) 1. 什么是线程? 线程是进程中的一个执行单元,它是 CPU 调度的基本单位。线程依赖于进程存在,一个进程可以包含多个线程,这些线程可以并发执行,提高程序的运行效率。...进程是承担系统分配系统资源的实体 线程是操作系统调度的基本单位 用一张图简要说明一下什么是线程: 首先我们要知道,在Linux中是没有实际的线程的,线程是被模拟出来的,Linux实际上使用LWP...LWP(Light Weight Process,轻量级进程)是 Linux 线程实现的一种机制,它与传统进程共享大部分资源,但仍有自己的调度信息。...创建线程 pthread_create是用于创建线程的函数,这个函数不是系统调用,因为Linux实际上是没有实体的线程,这个创建线程的函数是在pthread.h中封装的函数。...ps -aL 可以看见确实有两个线程,两个线程的pid是相同的,那哪一个是主线程,哪一个是新线程呢?pid和lwp相同的是主线程,pid和lwp不同的是新线程。

    1K00

    Linux多线程【线程池】

    ✨个人主页: 北 海 所属专栏: Linux学习之旅 操作环境: CentOS 7.6 腾讯云远程服务器 前言 线程池是一种管理线程的机制,它可以在需要时自动创建和销毁线程,以及分配和回收线程资源...总之多线程算是正式结束了,下一篇将会打开网络的大门 相关文章推荐 Linux多线程 =====:> 【初始多线程】、【线程控制】、【线程互斥与同步】、【生产者消费者模型】 Linux...进程信号 ===== :> 【信号产生】、【信号保存】、【信号处理】 Linux进程间通信 ===== :> 【消息队列、信号量】、【共享内存】、【命名管道】、【匿名管道】 Linux基础IO...】、【创建、终止、等待】 Linux进程学习 ===== :> 【进程地址】、【环境变量】、【进程状态】、【基本认知】 Linux基础 ===== :> 【gdb】、【git】、【gcc/g++...】、【vim】、Linux 权限理解和学习、听说Linux基础指令很多?

    1.8K40

    【Linux】线程的奥秘:Linux线程入门指南

    那么线程是什么,它和进程又有什么区别呢? 1. 什么是线程 线程(Thread)是操作系统中的一个重要的执行单元,是程序执行的最小调度单元。...线程存在于进程内部,一个进程可以包含一个或者多个线程,线程共享进程的资源并独立运行。 同时我们还要知道进程是承担系统资源分配的基本实体,而线程是CPU运行的基本单位。 2....开销 创建和切换开销较小 创建和切换开销较大 通信 同进程线程通信简单 需要使用 IPC(管道、共享内存等) 崩溃影响 一个线程崩溃会影响进程 一个进程崩溃对其他进程无直接影响 3.1 Linux与...Windows不同的线程设计 在Linux中,由于PCB和TCB的共同点太多了,于是直接复用了PCB的设计和调度策略,这样大大减少了系统的调度时的开销,因此Linux中实际没有真正的线程概念,有的只是复用了...在这种设计思想下,线程注定不会过于庞大,因此Linux中的线程又可以称为轻量级进程LWP,轻量级进程足够简单,且易于维护,效率更高、安全性强,可以使得Linux系统不间断的运行,不容易崩溃。

    75810

    【Linux】线程互斥之线程加锁

    一、锁的定义 线程加锁是在多线程编程环境中,为了确保在同一时刻只有一个线程能够访问特定的共享资源或执行特定的代码段,而采取的一种同步手段,通过在需要保护的资源或代码段前获取锁,在访问完成后释放锁,来实现对共享资源的互斥访问...有一段时间的票都是一个线程抢到的,我们预想的应该是几乎平均分配的样子 这说明了几个问题: 第一,线程对于锁的竞争能力不同,一定有一个首先抢到锁的线程 第二,一般来说,刚解锁再去抢锁的更容易一些...,类似于上面的结果,一直是线程1在抢票 (二)锁和线程 对于上面第二个问题来说,我们有处理方法,这种方法就是同步,同步可以让所有的线程按照一定的顺序获取锁 对于其他线程来讲,一个线程要么获取到了锁,要么释放了锁...,当前进程访问临界区的过程对于其他线程是原子的 在加锁期间,即解锁之前,是可以发生线程切换的,线程切换的时候是拿着锁走的,被锁起来的内容其他线程也是访问不到临界区的的,在该线程再次切换回来的时候,恢复线程上下文继续访问临界区代码...,结合操作系统内核态的底层同步原语支持以及库层面的合理封装,来确保操作的原子性),这样可以确保在多线程环境下对共享资源加锁和解锁操作的完整性与一致性,避免因多线程并发干扰导致锁状态异常,进而保障线程安全和数据的正确性

    53410

    【Linux】线程互斥

    线程互斥 一、互斥概念 大部分情况,线程使用的数据都是局部变量,变量的地址空间在线程栈空间内,这种情况,变量归属单个线程,其他线程无法获得这种变量。...但有时候,很多变量都需要在线程间共享,这样的变量称为共享变量,可以通过数据的共享,完成线程之间的交互。多个线程并发的操作共享变量,会带来一些问题。 例如下面我们模拟一个多线程抢票的程序。...那么假设我们现在有两个线程,分别为线程1和线程2,在线程执行的代码间隙中,线程是随时有可能会被切换的!而线程在执行的时候,将共享数据加载到 CPU 寄存器的本质就是把数据的内容变成了自己上下文的内容!...互斥锁接口 在 Linux 中,pthread 库给我们提供了一种互斥锁解决上面多线程访问共享数据不一致的问题。...所以对于其它线程来说,一个线程要么没有锁,要么释放锁,当前线程访问临界区的过程,对于其它线程是原子的! 3.

    77710

    Linux多线程

    线程是进程内部的一个执行流,在Linux下并没有为线程额外创建数据结构来管理,而是通过只建立PCB来模拟实现的;但是在Windows下为了管理线程又创建了TCB内核数据结构来管理; Linux这种方式一方面是提高了代码的复用率...,而是线程;线程的资源是占用进程的,所以进程其实是分配操作系统资源的基本单位 Linux下进程和线程的关系: 之前我们接触的都是单进程多线程或者多个单线程进程 3.线程的数据属性 一个进程内部的线程共享大部分的资源比如...Linux没有真正的线程,所以它没有提供创建线程的系统调用接口,只提供了轻量级进程的接口,所以要创建线程还需要借助原生线程库(pthread),但其实创建的还是轻量级进程,首先来认识一下创建接口 PTHREAD_CREATE...那么该全局变量则会映射到新线程的线程栈中,此后如果某一个线程修改了该全局变量不会影响到其他线程 ---- 线程控制 1.创建多线程 在Linux下连续创建10个线程,将自定义类对象传到新创建的线程中...:"Linux是64位系统,指针八字节 delete e; } cout线程退出

    1.3K30

    【高并发】终于弄懂为什么局部变量是线程安全的了!!

    写在前面 相信很多小伙伴都知道局部变量是线程安全的,那你知道为什么局部变量是线程安全的吗? 前言 多个线程同时访问共享变量时,会导致并发问题。那么,如果将变量放在方法内部,是不是还会存在并发问题呢?...fibonacci()方法来生成斐波那契数列,对于方法中的局部变量result,会不会存在线程安全的问题呢?...接下来,我们就深入分析下为什么局部变量不会存在线程安全的问题! 方法是如何被执行的? 我们以下面的三行代码为例。...很多人都知道,局部变量会存放在栈里。如果一个变量需要跨越方法的边界,就必须创建在堆里。 调用栈与线程 两个线程就可以同时用不同的参数调用相同的方法。那么问题来了,调用栈和线程之间是什么关系呢?...因为每个线程都有自己的调用栈,局部变量保存在线程各自的调用栈里,不会共享,自然也就不存在并发问题。 线程封闭 方法里的局部变量,因为不会和其他线程共享,所以不会存在并发问题。

    73630

    【Linux】线程互斥

    ,第2步在寄存器中对数据做--操作 线程A正准备做第3步时,时间片到了,线程A不能继续向后运行了 线程A要把自己的上下文保护起来,并且将寄存器中的数据也带走了 ---- 线程a认为值已经被改成99了...,所以无法执行第3步,把线程B的上下文保存起来 ---- 此时再次执行线程A,由于上次执行线程A时第3步没有执行,所以线程A继续执行第3步 但是内存中的g_val为上次线程B修改后的值10,又被改为99...第一种,锁为全局变量 ,直接用PTHREAD_MUTEX_INITIALIZER,对锁进行初始化 后面就不用 通过pthread_mutex_destroy 对其进行摧毁 ---- 第二种,若锁为局部变量...,就必须调用pthread_init 进行初始化,用完后也必须调用 pthread_destroy 进行销毁 pthread_metux_destroy 参数为锁 对锁进行销毁 若锁为局部变量 则需要在创建线程之前初始化...再将寄存器中的数据 与 内存中的数据 进行 交换 ---- 线程b 继续执行时 要进行判断 ,寄存器数据不大于0,当前线程被挂起 线程b申请锁失败 线程b 带走了自己的上下文 即 寄存器中的数据为0

    70730

    Linux线程调度

    在Linux中,线程是由进程来实现,线程就是轻量级进程( lightweight process ),因此在Linux中,线程的调度是按照进程的调度方式来进行调度的,也就是说线程是调度单元...Linux这样实现的线程的好处的之一是:线程调度直接使用进程调度就可以了,没必要再搞一个进程内的线程调度器。...在Linux中,调度器是基于线程的调度策略(scheduling policy)和静态调度优先级(static scheduling priority)来决定那个线程来运行。...下面介绍几种常见的调度策略: SCHED_OTHER:该策略是是默认的Linux分时调度(time-sharing scheduling)策略,它是Linux线程默认的调度策略。...那么在Linux中,在什么情况下要执行这个调度程序呢?我们把这种情况叫作调度时机。

    5K21

    【Linux】线程同步

    条件变量概念 所以怎么才能让线程按照一定的顺序去访问资源呢?也就是同步的解决方案是什么呢?这个解决方案在 Linux 中称为条件变量。 什么叫做条件变量呢?...而且,在资源就绪的时候,也就是有线程释放锁后,这个条件变量还需要提供一种通知机制,唤醒一个或者全部队列中的线程,让队头的线程去访问资源。这就是条件变量。...其中代码中的几个细节: 在执行生产线程和消费线程时,它们都是无序的,可能生产线程先调度,可能消费线程先调度,但真正进入代码执行的时候,一开始时,一定只能是生产者先运行!...在该线程访问资源期间,其它线程也只能在外面等着!...如下图: 四、线程池 线程池:一种线程使用模式。线程过多会带来调度开销,进而影响缓存局部性和整体性能。而线程池维护着多个线程,等待着监督管理者分配可并发执行的任务。

    77110

    Linux多线程【线程控制】

    ,需要先补充一波线程相关知识 1.2、线程私有资源 在 Linux多线程【初识线程】 中我们得出了一个结论:Linux 中没有真线程,只有复用 PCB 设计思想的 TCB 结构 因此 Linux 中的线程本质上就是...在 Linux 中,封装轻量级进程操作相关接口的库称为 pthread 库,即 原生线程库,这个库文件是所有 Linux 系统都必须预载的,用户使用多线程控制相关接口时,只需要指明使用 -lpthread...(独立栈),主线程中用的是进程系统栈,次线程用的是库中提供的栈 多个线程调用同一个入口函数(回调方法),其中的局部变量地址一定不一样,因为存储在线程独立栈中 3.3、理解线程局部存储 线程 之间共享 全局变量...多线程 =====:> 【初始多线程】 Linux进程信号 ===== :> 【信号产生】、【信号保存】、【信号处理】 Linux进程间通信 ===== :> 【消息队列、信号量】、【共享内存...===== :> 【gdb】、【git】、【gcc/g++】、【vim】、Linux 权限理解和学习、听说Linux基础指令很多?

    70530
    领券