首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么 StringBuilder 不是线程安全的?

我:StringBuilder不是线程安全的,StringBuffer是线程安全的 面试官:那StringBuilder不安全的点在哪儿? 我:。。。...(哑巴了) 在这之前我只记住了StringBuilder不是线程安全的,StringBuffer是线程安全的这个结论,至于StringBuilder为什么不安全从来没有去想过。...1、为什么输出值跟预期值不一样 我们先看一下StringBuilder的两个成员变量(这两个成员变量实际上是定义在AbstractStringBuilder里面的,StringBuilder和StringBuffer...假设这个时候count值为10,len值为1,两个线程同时执行到了第七行,拿到的count值都是10,执行完加法运算后将结果赋值给count,所以两个线程执行完后count值为11,而不是12。...至此,StringBuilder为什么不安全已经分析完了。如果我们将测试代码的StringBuilder对象换成StringBuffer对象会输出什么呢? 当然是输出10000啦!

59520

为什么 StringBuilder 不是线程安全的?

我:StringBuilder不是线程安全的,StringBuffer是线程安全的 面试官:那StringBuilder不安全的点在哪儿? 我:。。。...(哑巴了) 在这之前我只记住了StringBuilder不是线程安全的,StringBuffer是线程安全的这个结论,至于StringBuilder为什么不安全从来没有去想过。...1、为什么输出值跟预期值不一样 我们先看一下StringBuilder的两个成员变量(这两个成员变量实际上是定义在AbstractStringBuilder里面的,StringBuilder和StringBuffer...假设这个时候count值为10,len值为1,两个线程同时执行到了第七行,拿到的count值都是10,执行完加法运算后将结果赋值给count,所以两个线程执行完后count值为11,而不是12。...至此,StringBuilder为什么不安全已经分析完了。如果我们将测试代码的StringBuilder对象换成StringBuffer对象会输出什么呢? ? 当然是输出10000啦!

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

    为什么 StringBuilder 不是线程安全的?

    我:StringBuilder不是线程安全的,StringBuffer是线程安全的 面试官:那StringBuilder不安全的点在哪儿?我:。。。...(哑巴了) 在这之前我只记住了StringBuilder不是线程安全的,StringBuffer是线程安全的这个结论,至于StringBuilder为什么不安全从来没有去想过。...1、为什么输出值跟预期值不一样 我们先看一下StringBuilder的两个成员变量(这两个成员变量实际上是定义在AbstractStringBuilder里面的,StringBuilder和StringBuffer...假设这个时候count值为10,len值为1,两个线程同时执行到了第七行,拿到的count值都是10,执行完加法运算后将结果赋值给count,所以两个线程执行完后count值为11,而不是12。...至此,StringBuilder为什么不安全已经分析完了。如果我们将测试代码的StringBuilder对象换成StringBuffer对象会输出什么呢? ? 当然是输出10000啦!

    53030

    为什么 StringBuilder 不是线程安全的?

    我:StringBuilder 不是线程安全的,StringBuffer 是线程安全的 面试官:那 StringBuilder 不安全的点在哪儿? 我:。。。...(哑巴了) ❞ 在这之前我只记住了 StringBuilder 不是线程安全的,StringBuffer 是线程安全的这个结论,至于 StringBuilder 为什么不安全从来没有去想过。...StringBuilder线程安全 我们看到输出了“9326”,小于预期的 10000,并且还抛出了一个 ArrayIndexOutOfBoundsException 异常(异常不是必现)。...1、为什么输出值跟预期值不一样 我们先看一下 StringBuilder 的两个成员变量(这两个成员变量实际上是定义在 AbstractStringBuilder 里面的,StringBuilder 和...至此,StringBuilder 为什么不安全已经分析完了。如果我们将测试代码的 StringBuilder 对象换成 StringBuffer 对象会输出什么呢? 当然是输出 10000 啦!

    37220

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

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

    90250

    详解Spring中的Bean是不是线程安全的?

    前几天,就有好几个同学问我,在面试中被问到这样一个问题:Spring中的Bean是不是线程安全的?大家总觉得在面试过程差了一点意思,但是又说不上来是什么原因。...在多线程操作中只会对Bean的成员变量进行查询操作,不会修改成员变量的值,这样的Bean称之为无状态Bean。所以,可想而知,无状态的单例Bean是不存在线程安全问题的。...但是,在多线程操作中如果需要对Bean中的成员变量进行数据更新操作,这样的Bean称之为有状态Bean,所以,有状态的单例Bean就可能存在线程安全问题。...3、在类中定义 ThreadLocal 的成员变量,并将需要的可变成员变量保存在 ThreadLocal 中,ThreadLocal 本身就具备线程隔离的特性,这就相当于为每个线程提供了一个独立的变量副本...,每个线程只需要操作自己的线程副本变量,从而解决线程安全问题。

    68330

    变量的线程安全分析

    变量的线程安全 成员变量和静态变量是否线程安全?...局部变量是线程安全的 但局部变量引用的对象则未必 如果该对象没有逃离方法的作用访问,它是线程安全的 如果该对象逃离方法的作用范围,需要考虑线程安全 局部变量线程安全分析 public static void...,每个线程调用时会创建其不同实例,没有共享 而 method2 的参数是从 method1 中传递过来的,与 method1 中引用同一个对象 method3 的参数分析与 method2 相同 方法访问修饰符带来的思考...但注意它们多个方法的组合不是原子的  线程安全类方法的组合 分析下面代码是否线程安全?...具体来说,在Java中,String类的任何方法都是线程安全的,因为String类对象本身是不可变的,即String类的实例字段都声明为final类型,这些实例字段的值一旦被初始化后便无法更改,同时这些实例字段也没有提供任何可以修改它们的方法

    24520

    Spring中的Controller ,Service,Dao是不是线程安全的?

    作者:myseries cnblogs.com/myseries/p/11729800.html 结论:不是线程安全的 Spring容器中的Bean是否线程安全,容器本身并没有提供Bean的线程安全策略...spring单例,为什么controller、service和dao确能保证线程安全? Spring中的Bean默认是单例模式的,框架并没有对bean进行多线程的封装处理。...有状态就是有数据存储功能 无状态就是不会保存数据 controller、service和dao层本身并不是线程安全的,只是如果只是调用里面的方法,而且多线程调用一个实例的方法,会在内存中复制变量,这是自己的线程的工作内存...2 普通变量var:3 说明他不是线程安全的。...普通变量var:1 加了@Scope注解多的实例prototype是不是一定就是线程安全的呢?

    1.7K30

    bihash并不是线程安全的

    近期在vpp-dev订阅邮箱中有一个关于bihash的在查询过程中返回的value数值为-1,导致在后续使用中产生崩溃。所以认为bihash并不是线程安全的。下面就一起来看一下邮件的内容。...为此详细研究了bihash并提出了自己的解决方案: bihash线程不安全的原因 bihash表中的桶数永远不会改变。每个桶都有一个锁位。...该函数尽早获取桶锁并在持有锁的同时执行添加/删除/更新动作。显然这是安全的,我们需要关注读者。...关于 isolcpus,目前这是作为优化而不是先决条件提出的。如果没有 isolcpus,线程可能会被抢占任意长的时间。这意味着无论我们为版本字段分配多少位,有时它们都不够。...阅读器发布它要在 int rlock[MAX_THREADS] 数组中检查的桶号。每个线程在 rlock 中使用一个不同的单元(由线程 id 确定),因此它可以是一个常规写入,然后是一个屏障。

    94750

    WPF 支持的多线程 UI 并不是线程安全的

    WPF 支持创建多个 UI 线程,跨窗口的或者窗口内的都是可以的;但是这个过程并不是线程安全的。 你有极低的概率会遇到 WPF 多线程 UI 的线程安全问题,说直接点就是崩溃。...本文将讲述其线程安全问题。...简述这个线程安全问题 必要条件: 创建多个 WPF UI 线程 其实两个就够了,一个我们平时写的 App 类所在的主 UI 线程;一个后台 UI 线程,例如用来显示启动闪屏的 UI 线程 两个线程的话你需要大量重复试验才能复现...WPF 中在 Visual Studio 2019 抓到的异常: 复现步骤 创建一个新的 WPF 项目(无论是 .NET Framework 4.7.2 还是 .NET Core 3) 保持自动生成的...创建一个新的包含 Main 函数的 Program 类,并在项目属性中设置 Program 为启动对象(替代 App)。

    47220

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

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

    60130

    聊聊Servlet、Struts1、Struts2以及SpringMvc中的线程安全

    servlet Struts1 Struts2 springmvc 哪些是单例,哪些是多例,哪些是线程安全? 在谈这个话题之前,我们先了解一下Java中相关的变量类型以及内存模型JMM。...如果静态变量不是public和final类型,其命名方式与实例变量以及局部变量的命名方式一致。...所以在用Servlet构建的Web应用时如果不注意线程安全的问题,会使所写的Servlet程序有难以发现的错误。...Servlet的线程安全问题 Servlet的线程安全问题主要是由于实例变量使用不当而引起的,这里以一个现实的例子来说明。...总结 servlet Struts1 SpringMvc 是线程不安全的,当然如果你不使用实例变量也就不存在线程安全的问题了。

    1.2K140

    为什么ConcurrentHashMap是线程安全的?

    : JDK 1.7 线程安全实现 了解了 ConcurrentHashMap 的底层实现,再看它的线程安全实现就比较简单了。...也就是说 ConcurrentHashMap 的线程安全是建立在 Segment 加锁的基础上的,所以我们把它称之为分段锁或片段锁,如下图所示: JDK 1.8 底层实现 在 JDK 1.7 中,...JDK 1.8 线程安全实现 在 JDK 1.8 中 ConcurrentHashMap 使用的是 CAS + volatile 或 synchronized 的方式来保证线程安全的,它的核心实现源码如下...我们把上述流程简化一下,我们可以简单的认为在 JDK 1.8 中,ConcurrentHashMap 是在头节点加锁来保证线程安全的,锁的粒度相比 Segment 来说更小了,发生冲突和加锁的频率降低了...而 JDK 1.8 中 ConcurrentHashMap 使用的是数组+链表/红黑树的方式实现的,它是通过 CAS 或 synchronized 来实现线程安全的,并且它的锁粒度更小,查询性能也更高。

    95930

    JAVA中的线程安全

    ---- 1.java中的线程安全是什么      就是线程同步的意思,就是当一个程序对一个线程安全的方法或者语句进行访问的时候,其他的不能再对他进行操作了,必须等到这次访问结束以后才能对这个线程安全的方法进行访问...线程安全问题都是由全局变量及静态变量引起的。  ...若每个线程中对全局变量、静态变量只有读操作,而无写操作,一般来说,这个全局变量是线程安全的;若有多个线程同时执行写操作,一般都需要考虑线程同步,否则就可能影响线程安全。...存在竞争的线程不安全,不存在竞争的线程就是安全的 3.为什么有线程安全问题? 当多个线程同时共享,同一个全局变量或静态变量,做写的操作时,可能会发生数据冲突问题,也就是线程安全问题。...使用sybchronized的前提: (1).必须要有两个或者两个以上的线程 (2).必须是多个线程使用同一个锁 保证同步中只会有一个线程在运行 效率降低但是解决了多线程的安全问题 5.接下来用代码演示一下

    15530

    为什么说 HashMap 是非线程安全的?

    我们在学习 HashMap 的时候,都知道 HashMap 是非线程安全的,同时我们知道 HashTable 是线程安全的,因为里面的方法使用了 synchronized 进行同步。...但是 HashMap 为什么是非线程安全的呢?难道仅仅就是因为内部的方法没有 synchronized 关键字修饰吗?这篇文章主要来分析一下原因。...HashMap 在插入的时候 现在假如 A 线程和 B 线程同时进行插入操作,然后计算出了相同的哈希值对应了相同的数组位置,因为此时该位置还没数据,然后对同一个数组位置,两个线程会同时得到现在的头结点,...HashMap 在删除数据的时候 删除这一块可能会出现两种线程安全问题,第一种是一个线程判断得到了指定的数组位置i并进入了循环,此时,另一个线程也在同样的位置已经删掉了i位置的那个数据了,然后第一个线程那边就没了...其他地方还有很多可能会出现线程安全问题,我就不一一列举了,总之 HashMap 是非线程安全的,有并发问题时,建议使用 ConcrrentHashMap。 END

    85250
    领券