`
wanxiaotao12
  • 浏览: 457233 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

多线程-并发的概念,synchronize wait notify 的用法

 
阅读更多

转自:http://blog.csdn.net/weizhaozhe/article/details/3922647

注:wait notify 都是Object的方法

 

同步(阻塞) :是一种防止对共享资源访问导致的数据不一致的一种模式。

详细请参看操作系统。

 

在Java中,由于对多线程的支持,对同步的控制主要通过以下几个方法,synchronized,和wait(),notify()和notifyAll(),下面进行一一的讲解:

 

A关键字synchronized:对象锁

每个java对象都有一把, 当有多个线程同时访问共享资源的时候, 需要Synchronize 来控制安全性, synchronize 分 synchronize 方法 和synchronize,使用synchronize块时, 一定要显示的获得该对象的锁(如synchronize(object))而方法则不需要。

java的内存模型是对每一个进程有一个主内存, 每个线程有自己的内存, 他们从主内存中取数据, 然后计算, 再存入主内存中。

并发问题如下:如果多个线程同事操作同一数据, A线程从主内存中取的I的值为1, 然后进行加1操作, 这时B线程也取I的值, 进行加2操作, 然后A存入2到主内存中, B也存入, 这样就覆盖了A的值(同数据库中的并发问题一样)。

解决办法是用synchronize, 如用synchronized(I)。被synchronize 修饰的方法(块)把以下三步操作当成一个原子操作:取数据, 操作数据, 存数据。 我们知道原子操作是不可以被打断的, 所以其保证了数据一致性, 这样同一时间只有一个线程再执行, 对性能有一定的影响。这也是synchronize的第二个作用:保证统一时间只有一个线程再运行。 当实现SOCKET连接的时候经常用到.

JAVA中规定对非FLOAT, LONG的原始类型的取和存操作为原子操作。 其实就是对一个字(32位)的取,存位原始操作, 因为FLOAT, LONG为两个字节的长度, 所以其取, 存为非原子操作。 如果想把他们也变为原子操作, 可以用VOLATILE关键字来修饰

 

使用方法:

作用区域主要有两种:

1.方法

2.代码块

被synchronized声明的方法被称为同步方法,被其修饰的代码块称为同步语句。无论是同步方法还是同步语句,只要声明为同步了,在同一时刻,同一个对象的同步XX是不可以被同时访问的,而不同对象之间的同步方法是互不干扰的。

 

具体实现(如下代码都在某个类定义中):

同步方法:

Public synchronized void change() {

//

}

 

同步语句:(因为效率问题,有时考虑使用同步语句块)

Public void change() {

Synchronized(this) {

 

}

}

这个同步语句是针对当前对象的,有时,我们就是想让一段代码同步,可能与当前对象并没什么关系,可以自定义同步的锁。如下:

private byte[] lock= new byte[0];

 

 

Public void change() {

Synchronized(lock) {

 

}

}

自定义锁注意事项:

1必须是private,防止在类外部引用改变。

2如果可能用到,重写get方法,返回对象的clone,而不是本身。

 

 

 

 

其他用法:

Synchronized除了可以作用于方法,代码块,还可以作用于静态方法,类,某个实例。但是都存在效率问题,一定要慎用。

 

Class Foo   {   

 

publicsynchronizedstaticvoidmethodAAA()//同步的static 函数  

{   

 

//….  

 

}  

 publicvoidmethodBBB()   {   

 

synchronized(Foo.class)//class literal(类名称字面常量) 

 

 } }

这样修饰后代表的是:统一时刻,被修饰部分只有一个对象可以运行,因为它的声明是针对类的。

 

2.wait()/notify()/notifyAll()

 

注意:

在Java中,每个对象都有个对象锁标志(Object lock flag)与之想关联,当一个线程A调用对象的一段synchronized代码时,

它首先要获取与这个对象关联的对象锁标志,然后执行相应的代码,执行结束后,把这个对象锁标志返回给对象;因此,在线程A执行

synchronized代码期间,如果另一个线程B也要执行同一对象的一段synchronized代码时(不一定与线程A执行的相同),它将

要等到线程A执行完后,才能继续....

 

如何利用wait() notify() notifyAll()?

 

在synchronized代码被执行期间,线程可以调用对象的wait()方法,释放对象锁标志,进入等待状态,并且可以调用notify()或者

notifyAll()方法通知正在等待的其他线程。notify()通知等待队列中的第一个线程,notifyAll()通知的是等待队列中的所有线程

分享到:
评论

相关推荐

    publish-and-synchronize-test

    PublishAndSynchronizeTest模块 PublishAndSynchronizeTest提供用于P&S集成测试的测试基础结构。该模块也可以在生产中使用。 安装 composer require spryker/publish-and-synchronize-test 文献资料

    delphi vcl线程同步synchronize

    delphi vcl线程同步synchronize

    bcb 简单多线程实例

    最简单的多线程实例,适合初接触多线程的人员参考使用,BCB多线程实例。

    Delphi多线程教程

    Delphi中有一个线程类TThread是用来实现多线程编程的,这个绝大多数Delphi书藉都有说到,但基本上都是对TThread类的几个成员作一简单介绍,再说明一下Execute的实现和Synchronize的用法就完了。然而这并不是多线程编...

    java synchronize 线程同步

    当多个线程同时读写同一份共享资源的时候,可能会引起冲突。这时候,我们需要引入线程“同步”机制,即各位线程之间要有个先来后到,不能一窝蜂挤上去抢作一团。

    delphi多线程传递参数及同步二

    本代码介绍了如何给线程传递参数,以及用参数在主线程中显示数据

    Java对象锁和类锁全面解析(多线程synchronize

    Java对象锁和类锁全面解析(多线程synchronized关键字)编程开发技术共14页.pdf.zip

    4-Synchronize Robots_高清 720P.mp4

    4-Synchronize Robots_高清 720P.mp4

    delphi中的线程类

    Delphi中有一个线程类TThread是用来实现多线程编程的,这个绝大多数Delphi书藉都有说到,但基本上都是对TThread类的几个成员作一简单介绍,再说明一下Execute的实现和Synchronize的用法就完了。然而这并不是多线程...

    高级开发并发面试题和答案.pdf

    面试高级开发的期间整理的面试题目,记录我面试遇到过的并发题目以及答案 目录 并发 常说的并发问题是哪些;资源竞争、死锁、事务、可见性 死锁 如何排查死锁; 产生死锁的必要条件: 如何解决解决死锁; 锁 AQS:...

    GoldenGate安装部署及解决方案

    GoldenGate软件是一种基于日志的结构化数据复制软件,它通过解析源数据库在线日志或归档日志获得数据的增删改变化,再将这些变化应用到目标数据库,实现源数据库与目标数据库实时同步(real-time data synchronize)...

    Delphi中有一个线程类TThread是用来实现多线程编程

    Delphi中有一个线程类TThread是用来实现多线程编程的,这个绝大多数Delphi书藉都有说到,但基本上都是对TThread类的几个成员作一简单介绍,再说明一下Execute的实现和Synchronize的用法就完了。然而这并不是多线程...

    CALL RFC synchronize and asychronize Examples

    CALL RFC synchronize and asychronize Examples

    ado连接池实例

    Delphi TThread中文注释2009-10-22 16:58TThread是一个抽象类,可以创建几个独立的线程。 类关系 TObject 在一个多线程的应用程序中创建... (4)将使用VCL组件的任何调用传递给Synchronize方法,以避免多线程冲突。

    bcb6多线程计数器

    bcb6,含源码。 一个是直接读取edit的值,并且加1,在达到3个线程时,会发生冲突。 一个是采用Synchronize的方法避免。

    Synchronize It 3.5文件夹同步器 简体中文界面

    Synchronize It!还有其他特点如下: 1.可以自订许多的项目,包括过滤器、专案、颜色等等。 2.可以进行多种同步任务独立保存和点用,也可组合多个任务一次同步搞定。 3.支持压缩文件的同步。 4.内建二进位文件的比较...

    Java synchronize线程安全测试

    主要介绍了Java synchronize线程安全测试,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    多线程采集数据的delphi实例源代码.rar

    在Delphi中利用多线程实现数据采集的方法,代码包括了关于硬件端口读写的四个函数,还有模拟硬件的工作,  产生迟延,如果您的机器速度比较快,可以适当调整循环次数,在“暂停采集”按钮的OnClick事件中加入以下...

    delicious-cli:让您在本地镜像您的 nice.com 链接,并快速搜索它们(带有漂亮的颜色编码结果)

    Delicious.com命令行界面概念 该程序可让您在本地镜像您的美味链接,并快速搜索它们(具有漂亮的彩色编码结果)。...搜索查询> 具体选项: -s, --sync Synchronize links-r, --redownload Erase database and

    dependent-issues:GitHub动作,用于将问题标记为依赖于另一个

    使用以下内容创建.github/workflows/dependent-issues.yml : name : Dependent Issues on : issues : types : - opened - edited - reopened pull_request_target : types : - opened - edited - ...

Global site tag (gtag.js) - Google Analytics