黑马程序员技术交流社区
标题:
请教关键字strictfp的用途
[打印本页]
作者:
HM李帅
时间:
2013-3-8 13:24
标题:
请教关键字strictfp的用途
刚才看见一种写法
是 public static strictfp void main(String[] args) {
请问加上strictfp 与不加这个关键字的
public static void main(String[] args) {
有什么区别? 好像用法是一样的。。
作者:
张卫刚
时间:
2013-3-8 14:31
strictfp 关键字可应用于类、接口或方法;就是个精度问题,与有的硬件平台结合考虑,用static还是staticfp看情况吧,
你想让你的浮点运算更加精确,而且不会因为不同的硬件平台所执行的结果不一致的话,可以用关键字strictfp.
作者:
邹学良
时间:
2013-3-8 14:47
学习了!
之前都没见过这个strictfp 关键字,在网上查找了下,跟楼主分享下
strictfp关键字可应用于类、接口或方法。使用 strictfp 关键字声明一个方法时,该方法中所有的float和double表达式都严格遵守FP-strict的限制,符合IEEE-754规范。当对一个类或接口使用 strictfp关键字时,该类中的所有代码,包括嵌套类型中的初始设定值和代码,都将严格地进行计算。严格约束意味着所有表达式的结果都必须是 IEEE 754 算法对操作数预期的结果,以单精度和双精度格式表示。
如果你想让你的浮点运算更加精确,而且不会因为不同的硬件平台所执行的结果不一致的话,可以用关键字strictfp.
下面的示例演示了一个使用 strictfp 修饰符声明的类。
// Example of precision control with strictfp
public strictfp class MyClass
{
public MyClass(){}
public static void main(String[] args)
{
float aFloat = 0.6710339f;
double aDouble = 0.04150553411984792d;
double sum = aFloat + aDouble;
float quotient = (float)(aFloat / aDouble);
System.out.println("float: " + aFloat);
System.out.println("double: " + aDouble);
System.out.println("sum: " + sum);
System.out.println("quotient: " + quotient);
}
}
输出为:
float: 0.6710339
double: 0.04150553411984792
sum: 0.71253945297742238
quotient: 16.1673355
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2