浅谈synchronized方法对非synchronized方法的影响

2025-05-29 0 59

stringbuilder是线程不安全的类。

stringbuffer是线程安全的,因为它里面的方法加了synchronized

今天写了一段代码测试了一下:用循环开启10个线程,调用stringbuffer(stringbuilder)的append追加1 到 10 。

结果预期一样:线程不安全的stringbuilder会漏掉一些数字,

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22
public static void main(string[] args) throws interruptedexception {

stringbuffer buffer = new stringbuffer();

stringbuilder builder = new stringbuilder();

// 开启十个线程,分别对buffer 和 builder 操作

for(int i = 0; i < 10; i++) {

int j = i;

new thread(new runnable() {

public void run() {

try {

thread.sleep(500); //造成阻塞

} catch (interruptedexception e) {

e.printstacktrace();

}

builder.append(j);

}

}).start();

}

//等待以上操作完成

thread.sleep(1000);

// 打印结果

system.out.println("builder:"+builder);

}

浅谈synchronized方法对非synchronized方法的影响

线程安全的stringbuffer则追加了全部10个数字:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22
public static void main(string[] args) throws interruptedexception {

stringbuffer buffer = new stringbuffer();

stringbuilder builder = new stringbuilder();

// 开启十个线程,分别对buffer 和 builder 操作

for(int i = 0; i < 10; i++) {

int j = i;

new thread(new runnable() {

public void run() {

try {

thread.sleep(500); //造成阻塞

} catch (interruptedexception e) {

e.printstacktrace();

}

buffer.append(j);

}

}).start();

}

//等待以上操作完成

thread.sleep(1000);

// 打印结果

system.out.println("buffer:"+buffer);

}

浅谈synchronized方法对非synchronized方法的影响

这时:如果我同时操作builder和buffer,且先调用buffer的append,这时每次操作因为builder和buffer在同一个线程,builder的方法因为buffer阻塞了线程而被变成“同步”的方法,同样append了10个数字

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24
public static void main(string[] args) throws interruptedexception {

stringbuffer buffer = new stringbuffer();

stringbuilder builder = new stringbuilder();

// 开启十个线程,分别对buffer 和 builder 操作

for(int i = 0; i < 10; i++) {

int j = i;

new thread(new runnable() {

public void run() {

try {

thread.sleep(500); //造成阻塞

} catch (interruptedexception e) {

e.printstacktrace();

}

buffer.append(j);

builder.append(j);

}

}).start();

}

//等待以上操作完成

thread.sleep(1000);

// 打印结果

system.out.println("buffer:"+buffer);

system.out.println("builder:"+builder);

}

浅谈synchronized方法对非synchronized方法的影响

以上这篇浅谈synchronized方法对非synchronized方法的影响就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持快网idc。

原文链接:http://www.cnblogs.com/whatsoever/archive/2017/10/09/7643045.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 浅谈synchronized方法对非synchronized方法的影响 https://www.kuaiidc.com/114451.html

相关文章

发表评论
暂无评论