随笔 - 37  文章 - 1 评论 - 23 阅读 - 13万
< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8

1. native

native是方法修饰符。Native方法是由另外一种语言(如c/c++,FORTRAN,汇编)实现的本地方法。因为在外部实现了方法,所以在java代码中,就不需要声明了,有点类似于借口方法。Native可以和其他一些修饰符连用,但是abstract方法和Interface方法不能用native来修饰。

 

复制代码
public interface TestInterface {   
     
void doMethod();   
}
   
public class Test implements TestInterface {   
    
public native void doMethod();   
    
private native int doMethodB();   
   
public native synchronized String doMethodC();   
   
static native void doMethodD();   
}
  
复制代码

 

为什么需要使用native method?请参考:
http://www.javaeye.com/topic/72543 java Native Method初涉 

2. strictfp
修饰类和方法,意思是FP-strict,精确浮点。当JAVA虚拟机进行浮点运算时,如果没有指定strictfp关键字时,JAVA的编译器以及运行环境在对浮点运算的表达式是采取一种近似于我行我素的行为来完成这些操作,以致于得到的结果往往无法令你满意。而一旦使用了strictfp来声明一个类、接口或者方法时,那么所声明的范围内JAVA的编译器以及运行环境会完全依照浮点规范IEEE-754来执行。因此如果你想让你的浮点运算更加精确,而且不会因为不同的硬件平台所执行的结果不一致的话,那就请用关键字strictfp。。当一个class或interface用strictfp声明,内部所有的float和double表达式都会成为strictfp的。

注意:可以将一个类、接口以及方法声明为strictfp,但是不允许对接口中的方法以及构造函数声明strictfp关键字
 

复制代码
strictfp interface FPTest {   
     
void
 methodA();   
}
   
class FPClass implements FPTest 
{   
    
public void methodA() 
{   
    }
   
    
public void methodB() 
{   
  }
   
  
public strictfp void methodC() 
{   
  }
   
}
   
class FPClassB 
{   
    strictfp 
void methodA() 
{   
    }
   
}
  
复制代码

3.transient
变量修饰符(只能修饰字段)。标记为transient的变量,在对象存储时,这些变量状态不会被持久化。当对象序列化的保存在存储器上时,不希望有些字段数据被保存,为了保证安全性,可以把这些字段声明为transient。

Code

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

注意:因为异步线程可以访问字段,所以有些优化操作是一定不能作用在字段上的。volatile有时可以代替synchronized

复制代码
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。

Code
posted on   wxf0701  阅读(2334)  评论(2编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
点击右上角即可分享
微信分享提示