博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java中怎样创建线程安全的方法
阅读量:6161 次
发布时间:2019-06-21

本文共 1122 字,大约阅读时间需要 3 分钟。

面试问题:

下面的方法是否线程安全?怎样让它成为线程安全的方法?

class MyCounter {    private static int counter = 0;    public static int getCount() {        return counter++;    }}

本篇文章将解释一个常见的面试题,该问题被谷歌和很多其它公司问起过。它涉及的相对比较初级,而不是关于怎样去设计复杂的并发程序。

首先,这个问题的答案是No,因为counter++操作不是一个原子操作,而是由多个原子操作组成。

举个例子,在如下情况:一个线程正在访问该数据,另一个线程正在执行递增操作;

当线程Thread 1在t1时刻访问该方法,线程Thread 2有可能还没执行完这个方法的操作。因此,返回线程Thread 1的值有可能还没被递增过。

使getCount方法成为线程安全-方式一

使用关键字synchronized修饰getCount方法可以使它线程安全。当使用synchronized修饰静态方法,该类对象成为了锁。

使用synchronized就足够了吗,答案是Yes.

class MyCounter {    private static int counter = 0;    public static synchronized int getCount() {        return counter++;    }}

如果方法不是静态方法,那么使用关键字synchronized同步的将是实例对象,而不是类对象。

使getCount方法成为线程安全-方式二

在这个特殊的计数例子里,通过使用java.util.concurrent.atomic包下的AtomicInteger原子类,可以使count++操作变成原子操作,如下。

import java.util.concurrent.atomic.AtomicInteger;public class MyCounter {    private static AtomicInteger counter = new AtomicInteger(0);    public static int getCount() {        return counter.getAndIncrement();    }}

其它一些有用的关于线程安全的事实

在Java中本地变量是线程安全的。

每一个线程都会有一个自己的栈,两个不同的线程是不会共享同一个栈的。

所有方法内部的本地变量将会在栈中分配空间,一旦当前线程的方法执行完毕,栈帧将马上被移除。

 

译文链接:

 

转载地址:http://isefa.baihongyu.com/

你可能感兴趣的文章
pip安装Mysql-python报错EnvironmentError: mysql_config not found
查看>>
http协议组成(请求状态码)
查看>>
怎样成为一个高手观后感
查看>>
[转]VC预处理指令与宏定义的妙用
查看>>
MySql操作
查看>>
python 解析 XML文件
查看>>
MySQL 文件导入出错
查看>>
java相关
查看>>
由一个异常开始思考springmvc参数解析
查看>>
向上扩展型SSD 将可满足向外扩展需求
查看>>
虚机不能启动的特例思考
查看>>
SQL Server编程系列(1):SMO介绍
查看>>
在VMware网络测试“专用VLAN”功能
查看>>
使用Formik轻松开发更高质量的React表单(三)<Formik />解析
查看>>
也问腾讯:你把用户放在什么位置?
查看>>
CSS Sprites 样式生成工具(bg2css)
查看>>
[转]如何重构代码--重构计划
查看>>
类中如何对list泛型做访问器??
查看>>
C++解析XML--使用CMarkup类解析XML
查看>>
P2P应用层组播
查看>>