synchronized和native关键字的使用方法

原创 2007年09月14日 22:42:00

一、 Synchronized关键字       

        关键字synchronized可以作为JAVA方法修饰符,也可以作为JAVA方法内的语句。
被它修饰的代码部分往往被描述为临界区。这使很多人认为,由于代码被syscharonized保护着,因此同一时刻只能有一个线程访问它。
对于JAVA类中的方法,关键字sysnchronized其实并不锁定该方法或该方法的部分代码,它只是锁定对象。
当synchronized被当做方法修饰符的时候,他所取得的lock将被交给方法调用者(某对象)。如果synchronized作用于某对象的引用,则取得的lock将交给该引用所指的对象。
对一个对象进行同步控制到底意味什么呢?它说明调用该方法的线程将会取得对象的lock。持有对象A的lock的线程,如果另外通过synchronized函数或者synchronized语句来申请对象A的lock的线程,在该lock被释放前无法获得满足。
因此,synchronized方法或synchronized区段内的代码在同一时刻下可有多个线程执行,只要是对不同的对象调用该方法。

1. synchronized 方法:通过在方法声明中加入 synchronized关键字来声明 synchronized 方法。如:  

  public synchronized void accessVal(int newVal);
  
   synchronized 方法控制对类成员变量的访问:每个类实例对应一把锁,每个 synchronized 方法都必须获得调用该方法的类实例的锁方能执行,否则所属线程阻塞,方法一旦执行,就独占该锁,直到从该方法返回时才将锁释放,此后被阻塞的线程方能获得该锁,重新进入可执行状态。 

  这种机制确保了同一时刻对于每一个类实例,其所有声明为 synchronized 的成员函数中至多只有一个处于可执行状态(因为至多只有一个能够获得该类实例对应的锁),从而有效避免了类成员变量的访问冲突(只要所有可能访问类成员变量的方法均被声明为 synchronized)。 

  在Java中,不光是类实例,每一个类也对应一把锁,这样我们也可将类的静态成员函数声明为 synchronized ,以控制其对类的静态成员变量的访问。 

  synchronized 方法的缺陷:若将一个大的方法声明为synchronized 将会大大影响效率,典型地,若将线程类的方法 run() 声明为 synchronized ,由于在线程的整个生命期内它一直在运行,因此将导致它对本类任何 synchronized 方法的调用都永远不会成功。当然我们可以通过将访问类成员变量的代码放到专门的方法中,将其声明为 synchronized ,并在主方法中调用来解决这一问题,但是 Java为我们提供了更好的解决办法,那就是 synchronized 块。 

  2. synchronized 块:通过 synchronized关键字来声明synchronized 块。语法如下: 

  synchronized(syncObject)
  { 
  //允许访问控制的代码 
  }
  
  synchronized 块是这样一个代码块,其中的代码必须获得对象 syncObject (如前所述,可以是类实例或类)的锁方能执行,具体机制同前所述。由于可以针对任意代码块,且可任意指定上锁的对象,故灵活性较高。

二、 Native关键字
     使用native关键字说明这个方法是原生函数,也就是这个方法是用C/C++语言实现的,并且被编译成了DLL,由java去调用。
这些函数的实现体在DLL中,JDK的源代码中并不包含,你应该是看不到的。对于不同的平台它们也是不同的。这也是java的底层机制,实际上java就是在不同的平台上调用不同的native方法实现对操作系统的访问的。
java是跨平台的语言,既然是跨了平台,所付出的代价就是牺牲一些对底层的控制,而java要实现对底层的控制,就需要一些其他语言的帮助,这个就是native的作用了
       

 3.   native方法

       native方法是用户在java中可以使用,但不能编写的方法。

      JNI(Java Native Interface),它允许Java虚拟机(Jvm)内部运行的Java代码能够与用其它编程语言编写的应用程序和库进行互操作。

      JNI最大的好处是它没有对底层Java虚拟机的实现施加任何限制,因此,Java虚拟机厂商可以在不影响虚拟机其它部分的情况下添加对JNI的支持。程序员只需编写一种版本的本地(Native)应用程序和库,就能够与所有支持JNI的Java虚拟机协同工作

 

相关文章推荐

[转载]关于native,transient,volatile,synchronized四个关键字的使用

转载:http://www.blogjava.net/bacoo/archive/2007/12/20/169172.html native 当你需要调用本地程序的时候 transient ...

C#中的yield关键字的使用方法介绍

yield这个关键字是和迭代器挂钩的,而且是与return一起以yield return的形式合用的,用来返回迭代器中的条目。 yield不能单独放在try-catch块中,如果try中有yield...

Java transient关键字的作用及使用方法

refs: http://www.cnblogs.com/lanxuezaipiao/p/3369962.html 1. transient的作用及使用方法       ...

c语言程序的存储区域与const关键字的使用方法

一.C语言程序的存储区域 1.由C语言代码(文本文件)形成可执行程序(二进制文件),需要经过编译-汇编-连接三个阶段。编译过程把C语言文本文件生成汇编程序,汇编过程把汇编程序形成二进制机器代码,连接...
  • Fybon
  • Fybon
  • 2014年01月12日 22:01
  • 725

c语言程序的存储区域与const关键字的使用方法

一.C语言程序的存储区域 1.由C语言代码(文本文件)形成可执行程序(二进制文件),需要经过编译-汇编-连接三个阶段。编译过程把C语言文本文件生成汇编程序,汇编过程把汇编程序形成二进制机器代码,...

SQL中TOP关键字的使用方法

在编写程序中,我们可能遇到诸如查询最热门的5篇文章或返回满足条件的n条记录的情况,在SQL语言中,可以使用TOP关键字来实现。 TOP关键字在SQL语言中用来限制返回结果集中的记录条数,其使用方法有...

Robot Framework-用户关键字的使用方法

在进行软件自动化测试时,我们设计并编写好一个测试脚本的业务逻辑之后,需要将其中的“业务数据”提取为变量,并对业务逻辑进行封装,以便在后续的测试过程中,只需设置每次测试的测试数据,而不必更改业务逻辑。 ...

c语言程序的存储区域与const关键字的使用方法

一.C语言程序的存储区域 1.由C语言代码(文本文件)形成可执行程序(二进制文件),需要经过编译-汇编-连接三个阶段。编译过程把C语言文本文件生成汇编程序,汇编过程把汇编程序形成二进制机器代码,...

C++中typename关键字的使用方法和注意事项

1, 什么地方使用?用在模板定义里,标明其后的模板参数是类型参数。 例如   template T foo(const T& t, const Y& y){//....}; temp...

java final关键字的理解与使用方法总结二

本文接上一篇,对final方法和final类进行说明 1、定义为final的方法不能被重写 2、书上写:定义为final的方法的执行效率高于非final的方法。由于final方法通过机器码生成器或者优...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:synchronized和native关键字的使用方法
举报原因:
原因补充:

(最多只允许输入30个字)