java float double string转换和根据是否是小数判断显示格式

/**
*  根据传入的float类型判断精度 小数保留两位小数,整数不保留
*
*/
public class TestFloatToInt
{
	public static String test(float f){
		DecimalFormat df=new DecimalFormat("#0.00");
		String str=df.format(f).toString();
		if(str.split("\\.")[1].equals("00")){
			str=str.split("\\.")[0];
		}
		return str;
	}


	public static void main(String[] args)
	{
		
		System.out.println(test((float)1223432.99999f));


	}
}
import java.text.DecimalFormat;
import java.util.regex.Pattern;
/**
 * 根据传入字符串判断小数,float,整数(未对传入字符进行校验,遗留默认传入格式为1233或者123.33 或者12321.11f等)
 * @author Cloudy
 *
 */
public class TestFloatToInt
{
	public static String test(String src){
		DecimalFormat df=new DecimalFormat("#0.00");
		//如果是小数
		if(Pattern.compile("[0-9]*(\\.)[0-9]*").matcher(src).find()){
			//判断为float类型
			if(Pattern.compile("\\.*[a-zA-Z]+\\.*").matcher(src).find()){
				float float_str=Float.valueOf(src);
				String str=df.format(float_str).toString();
				if(str.split("\\.")[1].equals("00")){  
		            str=str.split("\\.")[0];  
		        }  
				return str;
			}
			else{
				double d_str=Double.parseDouble(src);
				String str_1=df.format(d_str).toString();
				if(str_1.split("\\.")[1].equals("00")){  
					str_1=str_1.split("\\.")[0];  
		        }  
				return str_1;
			}
			
		}

		else{
			float f_strr=Float.valueOf(src);
			String str_3=df.format(f_strr).toString();
			if(str_3.split("\\.")[1].equals("00")){  
				str_3=str_3.split("\\.")[0];  
	        }  
			return str_3;
		}
	}

	public static void main(String[] args)
	{
		
		System.out.println(test("55551.267"));

	}
}



### Java 中 `double` `float` 类型的区别 #### 存储空间与精度差异 在 Java 中,`double` `float` 都用于表示浮点数值,但两者之间存在显著的不同之处。主要体现在存储空间以及所能达到的精度上。 - **float**: 占用 4 字节(32位),提供大约 6 到 7 位有效数字的精度[^1]。 - **double**: 使用 8 字节(64位)来保存数据,能够支持约 15 至 16 位的有效数字。 因此,在涉及高精度计算场景下推荐使用 `double` 而不是 `float` ,以减少舍入误差带来的影响。 #### 定义方式上的不同 当声明一个变量为 `float` 类型时,如果赋给它一个小数,默认情况下会被视为 `double` 型常量,这会导致编译错误除非显式转换或添加特定后缀[f/F][^3]: ```java // 错误示范 float num = 1.3; // 正确做法之一:强制类型转换 float correctNum1 = (float) 1.3; // 或者指定为 float 文字量 float correctNum2 = 1.3f; ``` 对于 `double` 来说,则不需要这样的特殊处理,可以直接初始化而无需额外标记[d/D],不过也可以加上作为习惯性的良好实践[^4]: ```java double piApproximation = 3.141592653589793d; ``` #### 输出展示特性 由于内部实现机制的原因,即使同一个原始值被赋予不同的浮点数类型,最终打印出来的结果也可能有所差别。例如下面的例子展示了如何因类型不同而导致显示效果的变化: ```java public class Main { public static void main(String[] args){ float fValue = 3.1415926999999F; double dValueFromFloat = fValue; double dValueDirectlyAssigned = 3.1415926999999; System.out.println("Float value: " + fValue); System.out.println("Double from float conversion: " + dValueFromFloat); System.out.println("Directly assigned double value: " + dValueDirectlyAssigned); } } ``` 这段程序将会输出如下内容: ``` Float value: 3.1415927 Double from float conversion: 3.1415927410125732 Directly assigned double value: 3.1415926999999 ``` 可以看到即使是相同的初始值,经过不同类型间的转化之后其表现形式也会有所不同。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值