Java如何处理多线程的数据同步问题
在这里写这种文章好奇怪,先用作笔记吧
Java中有如下的方法来处理代码块的并发访问问题:
一是关键字synchronized
二是加锁(锁对象,条件对象)
Java给每一个对象都提供了一个内部锁,在方法的定义中加上关键字synchronized后,那么对象的锁将保护整个方法。也就是说下面两种写法是等价的:
public synchronized void method()
{
......
}
public void method()
{
this.intrinsickLock.lock();
try
{
......
}
finally
{
this.intrinsickLock.unlock;
}
}
Java Core中对以上两种方式都不推荐!
关键词synchronized解读:
synchronized实现原理就是Java为每一个对象都内置了一个锁。对于一个类的普通方法来说,synchronized锁住的是每一个new出来的对象的方法,比如说对于如下代码:
public class Test{
public void synchronized testMethod()
{
.......
}
}
Test obj1 = new Test();
Test obj2 = new Test();
如果Thread-1 访问的是obj1,Thread-2访问的是obj2,那么两个线程都不会阻塞,因为这是两个不同的对象。
如果Thread-1 访问的是obj1,Thread-2访问的也是obj1,那么Thread-2会阻塞,因为两个线程访问的是同一个的对象,但是Thread-1先获取了锁,所以Thread-2必须等到Thread-1释放了锁,才能访问。
对于一个静态方法而言,synchronized则成为了一个类锁,对于上面所描述的场景,两种情况下,Thread-2都会被阻塞,因为静态方法是类的所有对象都共享的。
synchronized除了能锁整个方法之外,也能锁代码块。
一种写法是:
public void method()
{
synchronized(this)
{
....
}
.....
}
另外一种写法是:
Object obj = new Object();
public void method()
{
synchronized(obj)
{
....
}
.....
}
第二种写法更加灵活一些。在用synchronized的时候,需要当心的是过度使用synchronized来进行保护,造成性能的问题。
- Java如何处理多线程的数据同步问题
- Java如何利用synchronized处理多线程的数据同步问题
- 集群中多线程如何处理表中的数据的问题
- java多线程的等待唤醒机制及如何解决同步过程中的安全问题
- Java多线程(八):锁对象Lock-同步问题更完美的处理方式
- JAVA基础知识之java多线程时数据同步问题
- Java多线程环境下如何高效安全处理数据(输入输出流、文件、网络等)(一)
- java线程研究---(7)Thread同步:多线程数据共用会产生问题
- 如何处理集群、分布架构的数据同步问题
- java多线程处理导入数据拆分List集合,同步处理插入数据
- java多线程处理导入数据拆分List集合,同步处理插入数据
- java多线程处理导入数据拆分List集合,同步处理插入数据
- 如何实现多个线程同步 (2013-11-10 12:07:24)转载▼ 标签: it 在编写一个类时,如果该类中的代码可能运行于多线程环境下,那么就要考虑同步的问题,Java实现线程同步的方法很多
- java多线程:锁对象Lock-同步问题更完美的处理方式
- 浅谈Java多线程的同步问题
- java(多线程)实现高性能数据同步
- 【转】浅谈Java多线程的同步问题
- 浅谈Java多线程的同步问题【转载】
- 浅谈Java多线程的同步问题
- 浅谈Java多线程的同步问题