课程咨询 :186 8716 1620      qq:2066486918

昆明Java培训 > 达内新闻 > Java 5以前的并发编程
  • Java 5以前的并发编程

    发布:昆明Java培训      来源:达内新闻      时间:2016-11-17

  • 昆明Java培训机构的老师知道,Java的线程模型建立在抢占式线程调度的基础上,也就是说:

    所有线程可以很容易的共享同一进程中的对象。

    能够引用这些对象的任何线程都可以修改这些对象。

    为了保护数据,对象可以被锁住。

    Java基于线程和锁的并发过于底层,而且使用锁很多时候都是很万恶的,因为它相当于让所有的并发都变成了排队等待。

    在Java 5以前,可以用synchronized关键字来实现锁的功能,它可以用在代码块和方法上,表示在执行整个代码块或方法之前线程必须取得合适的锁。对于类的非静态方法(成员方法)而言,这意味这要取得对象实例的锁,对于类的 态方法(类方法)而言,要取得类的Class对象的锁,对于同步代码块,程序员可以指定要取得的是那个对象的锁。

    不管是同步代码块还是同步方法,每次只有一个线程可以进入,如果其他线程试图进入(不管是同一同步块还是不同的同步块),JVM会将它们挂起(放入到等锁池中)。这种结构在并发理论中称为临界区(critical section)。这里 们可以对Java中用synchronized实现同步和锁的功能做一个总结:

    只能锁定对象,不能锁定基本数据类型

    被锁定的对象数组中的单个对象不会被锁定

    同步方法可以视为包含整个方法的synchronized(this) {…}代码块

    静态同步方法会锁定它的Class对象

    内部类的同步是独立于外部类的

    synchronized修饰符并不是方法签名的组成部分,所以不能出现在接口的方法声明中

    非同步的方法不关心锁的状态,它们在同步方法运行时仍然可以得以运行

    synchronized实现的锁是可重入的锁。

    在JVM内部,为了提高效率,同时运行的每个线程都会有它正在处理的数据的缓存副本,当我们使用synchronzied进行同步的时候,真正被同步的是在不同线程中表示被锁定对象的内存块(副本数据会保持和主内存的同步,现在知道 什么要用同步这个词汇了吧),简单的说就是在同步块或同步方法执行完后,对被锁定的对象做的任何修改要在释放锁之前写回到主内存中;在进入同步块得到锁之后,被锁定对象的数据是从主内存中读出来的,持有锁的线程 数据副本一定和主内存中的数据视图是同步的。

    在Java最初的版本中,就有一个叫volatile的关键字,它是一种简单的同步的处理机制,因为被volatile修饰的变量遵循以下规则:

    变量的值在使用之前总会从主内存中再读取出来。

    对变量值的修改总会在完成之后写回到主内存中。

    使用volatile关键字可以在多线程环境下预防编译器不正确的优化假设(编译器可能会将在一个线程中值不会发生改变的变量优化成常量),但只有修改时不依赖当前状态(读取时的值)的变量才应该声明为volatile变量。

    不变模式也是并发编程时可以考虑的一种设计。让对象的状态是不变的,如果希望修改对象的状态,就会创建对象的副本并将改变写入副本而不改变原来的对象,这样就不会出现状态不一致的情况,因此不变对象是线程安全的 Java中我们使用频率极高的String类就采用了这样的设计。说到这里你可能也体会到final关键字的重要意义了。

    了解详情请登陆昆明达内Java培训官网(km.Java.tedu.cn)!

    推荐文章

上一篇:Realm Java原理介绍以及常见问题

下一篇:java编程的原子类

最新开班日期  |  更多

Java--零基础全日制班

Java--零基础全日制班

开班日期:11/30

Java--零基础业余班

Java--零基础业余班

开班日期:11/30

Java--周末提升班

Java--周末提升班

开班日期:11/30

Java--零基础周末班

Java--零基础周末班

开班日期:11/30

  • 网址:http://km .java.tedu.cn      地址:昆明市官渡区春城路62号证券大厦附楼6楼
  • 课程培训电话:186 8716 1620      qq:2066486918    全国服务监督电话:400-827-0010
  • 服务邮箱 ts@tedu.cn
  • 2001-2016 达内国际公司(TARENA INTERNATIONAL,INC.) 版权所有 京ICP证08000853号-56