Java中的native,transient,volatile和strictfp关键字

Java中的native,transient,volatile和strictfp关键字

Java中的native,transient,volatile和strictfp关键字

博客分类: J2SEJavaJ#JNI VC ++Fortran写道1,native是方法修饰符。Native方法是由另外一种语言(如c/c++,FORTRAN,汇编)实现的本地方法。一般用于JNI中。 

public class testdll 

static 

System.loadLibrary("test"); 


public native static int get(); 

public native static void set(int i); 

public static void main(String[] args) 

testdll test = new testdll(); 
test.set(10); 
System.out.println(test.get()); 



test.dll可以用VC写,例如, 
-----testdll.h----- 
/* DO NOT EDIT THIS FILE - it is machine generated */ 
#include <jni.h> 
/* Header for class testdll */ 

#ifndef _Included_testdll 
#define _Included_testdll 
#ifdef __cplusplus 
extern "C" { 
#endif 
/* 
* Class: testdll 
* Method: get 
* Signature: ()I 
*/ 
JNIE XP ORT jint JNICALL Java_testdll_get 
(JNIEnv *, jclass); 

/* 
* Class: testdll 
* Method: set 
* Signature: (I)V 
*/ 
JNIEXPORT void JNICALL Java_testdll_set 
(JNIEnv *, jclass, jint); 

#ifdef __cplusplus 

#endif 
#endif 


-------testdll.c----------- 
#include "testdll.h" 

int i = 0; 

JNIEXPORT jint JNICALL Java_testdll_get (JNIEnv *, jclass) 

return i; 


JNIEXPORT void JNICALL Java_testdll_set (JNIEnv *, jclass, jint j) 

i = j; 
}写道2,transient 

transient是一个变量修饰符,标记为transient的变量,在对一个对象进行序列化时,这些变量状态不会被序列化。 

例如,假设某个类的成员变量是transient,那么当通过ObjectOutputStream把这个类的某个实例保存到磁盘上时,实际上transient变量的值是不会保存的。 

当对象序列化的保存在存储器上时,不希望有些字段 数据 被保存,为了保证安全性,可以把这些字段声明为transient。 

要更明白,可以看一些序列化的内容。

 

写道3,volatile 
CSDN 有一篇介绍过,现贴回来。 

volatile修饰变量。在每次被线程访问时,都强迫从共享内存中重读该成员变量的值。而且,当成员变量发生变化时,强迫线程将变化值回写到共享内存。这样在任何时刻,两个不同的线程总是看到某个成员变量的同一个值。 
看看Java Language Specification中的例子。 
条件:一个线程不停的调用方法one(),一个线程不停的调用方法two()。我测试过多次,这种情况好像一直没有出现。 

代码 
class Test { 
static int i = 0, j = 0; 
static void one() { i++; j++; } 
static void two() { 
System.out.println("i=" + i + " j=" + j); 



结果偶尔会出现j大于i的情况,因为方法没有同步,所以会出现i和j可能不是一次更新。一种防止这种情况发生的办法就是声明两个方法为synchronized 的。 

代码 
class Test { 
static int i = 0, j = 0; 
static synchronized void one() { i++; j++; } 
static synchronized void two() { 
System.out.println("i=" + i + " j=" + j); 



这样可以防止两个方法同时被执行,还可以保证j和i被同时更新,这样一来i和j的值一直是一样的。 
另外一种途径就是把i和j声明为volatile。 

代码 
class Test { 
static volatile int i = 0, j = 0; 
static void one() { i++; j++; } 
static void two() { 
System.out.println("i=" + i + " j=" + j); 

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java语言关键字是指具有特殊含义的单词,这些单词在Java程序具有特定的用途,不能作为标识符或变量名使用。Java共有50个关键字,其包括48个保留关键字和2个特殊关键字。 以下是Java的各种关键字: 1. abstract:用于定义抽象类和抽象方法。 2. assert:用于调试程序时进行断言判断,如果条件不成立将会抛出AssertionError异常。 3. boolean:用于定义布尔类型变量,只能取值true或false。 4. break:用于跳出循环语句。 5. byte:用于定义字节类型变量,取值范围为-128到127。 6. case:用于在switch语句匹配选项。 7. catch:用于捕获异常。 8. char:用于定义字符类型变量。 9. class:用于定义类。 10. const:Java虽然保留了此关键字,但并没有使用,因此不能用于定义常量。 11. continue:用于跳过循环的某个迭代。 12. default:用于switch语句的默认选项。 13. do:用于定义do-while循环。 14. double:用于定义双精度浮点类型变量。 15. else:用于if语句条件不成立时执行的代码块。 16. enum:用于定义枚举类型。 17. extends:用于继承一个类或实现一个接口。 18. final:用于定义常量或不可变的变量,或者修饰类、方法、变量等,表示其不可再被继承、重写或修改。 19. finally:用于定义无论是否有异常发生都需要执行的代码块。 20. float:用于定义单精度浮点类型变量。 21. for:用于定义for循环。 22. goto:Java虽然保留了此关键字,但并没有使用,因此不能跳转到标签。 23. if:用于定义条件语句。 24. implements:用于实现一个接口。 25. import:用于导入其他类的定义。 26. instanceof:用于判断一个对象是否属于某个类或实现了某个接口。 27. int:用于定义整型变量。 28. interface:用于定义接口。 29. long:用于定义长整型变量。 30. native:用于调用本地方法。 31. new:用于创建一个对象。 32. package:用于定义包。 33. private:用于定义私有成员,只能在当前类访问。 34. protected:用于定义受保护的成员,只能在当前类及其子类和同一个包访问。 35. public:用于定义公共成员,可以被任何类访问。 36. return:用于从方法返回值。 37. short:用于定义短整型变量。 38. static:用于定义静态成员,只有一个拷贝,可以通过类名直接访问。 39. strictfp:用于声明浮点数计算具有严格的规范化行为。 40. super:用于引用父类的成员。 41. switch:用于定义switch语句。 42. synchronized:用于定义同步方法或同步代码块。 43. this:用于引用当前对象。 44. throw:用于抛出异常。 45. throws:用于声明方法可能抛出的异常。 46. transient:用于声明不需要持久化的变量。 47. try:用于定义异常处理代码块。 48. void:用于定义无返回值的方法。 49. volatile:用于声明变量是易变的,即每次访问都需要从主存读取。 50. while:用于定义while循环。 以上就是Java的各种关键字,这些关键字Java程序起着非常重要的作用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值