在进行double类型的数字计算时,如果直接用加减乘除的符号进行换算时,总是会碰到有时候差几分。总是很苦恼,尤其是对于涉及到钱的交易系统中,计算的精准性就更显得尤为重要。故放开公式计算的类,供以后参考。
import java.math.BigDecimal;
import java.text.DecimalFormat;
import org.apache.commons.lang.StringUtils;
public class DoubleUtils {
private static final int DEF_DIV_SCALE = 10;
/**
* 提供精确的加法运算 7. * @param v1 被加数 8. * @param v2 加数 9. * @return 两个参数的和
*
*/
public static int compareWeight(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
b1 = b1.setScale(4, BigDecimal.ROUND_HALF_UP);
b2 = b2.setScale(4, BigDecimal.ROUND_HALF_UP);
return b1.compareTo(b2);
}
/**
* 金额的比较
* @return
*/
public static int compareMoney(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
b1 = b1.setScale(2, BigDecimal.ROUND_HALF_UP);
b2 = b2.setScale(2, BigDecimal.ROUND_HALF_UP);
return b1.compareTo(b2);
}
/**
* 提供精确的加法运算
* @param v1 被加数
* @param v2 加数
* @return 两个参数的和
*
*/
public static double add(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.add(b2).doubleValue();
}
/**
* 提供精确的减法运算
* @return
*/
public static double substract(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.subtract(b2).doubleValue();
}
/**
* 提供精确的乘法运算
* @return
*/
public static double multiply(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.multiply(b2).doubleValue();
}
/**
* * 提供(相对)精确的除法运算,当发生除不尽的情况时, 精确到小数点以后10位,以后的数字四舍五入.
* @param v1 被除数
* @param v2 除数
* @return 两个参数的商.
*/
public static double divide(double v1, double v2) {
return divide(v1, v2, DEF_DIV_SCALE);
}
/**
* 提供(相对)精确的除法运算. 当发生除不尽的情况时,由scale参数指 定精度,以后的数字四舍五入.
* @param v1 被除数
* @param v2 除数
* @param scale 表示需要精确到小数点以后几位
* @return 两个参数的商
*/
public static double divide(double v1, double v2, int scale) {
if (scale < 0) {
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
}
/**
* 提供精确的小数位四舍五入处理
* @param v 需要四舍五入的数字
* @param scale 小数点后保留几位
* @return 四舍五入后的结果
*/
public static double round(double v, int scale) {
if (scale < 0) {
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b = new BigDecimal(Double.toString(v));
BigDecimal one = new BigDecimal("1");
return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
}
public static double roundMoney(double v) {
BigDecimal b = new BigDecimal(Double.toString(v));
BigDecimal one = new BigDecimal("1");
return b.divide(one, 2, BigDecimal.ROUND_HALF_UP).doubleValue();
}
public static double roundWeight(double v) {
BigDecimal b = new BigDecimal(Double.toString(v));
BigDecimal one = new BigDecimal("1");
return b.divide(one, 4, BigDecimal.ROUND_HALF_UP).doubleValue();
}
public static String toMoney(double amount) {
DecimalFormat df = new DecimalFormat("0.00");
return df.format(amount);
}
/**
* 将以元为单位的金额转换成以分为单位的金额
*
* @param amount
* @return
*/
public static String toMinuteMoney(double amount) {
if (compareMoney(amount, 0) == 0)
return "0";
DecimalFormat df = new DecimalFormat("0");
return df.format(multiply(roundMoney(amount), 100));
}
/**
* 将以元为单位的金额转换成以分为单位的金额
*
* @param amount
* @return
*/
public static double toYuanMoney(double amount) {
if (compareMoney(amount, 0) == 0)
return amount;
return roundMoney(divide(amount, 100));
}
/**
* 将以元为单位的金额转换成以分为单位的金额
*
* @param amount
* @return
*/
public static double toYuanMoney(String amount) {
if (StringUtils.isBlank(amount))
return 0;
return roundMoney(divide(Double.parseDouble(amount), 100));
}
/**
* 将放大了10000倍后的利率还原成原形
*
* @param rate
* @return
*/
public static double toRealRate(String rate) {
if (StringUtils.isBlank(rate))
return 0;
return round(divide(Double.parseDouble(rate), 10000), 5);
}
/**
* 将放大了10000倍后的利率
*
* @param rate
* @return
*/
public static String toMaxRate(double rate) {
if (compareMoney(rate, 0) == 0)
return "0";
DecimalFormat df = new DecimalFormat("0");
return df.format(multiply(roundMoney(rate), 10000));
}
public static void main(String[] args) {
double str = DoubleUtils.toYuanMoney("1100007");
System.out.println(str);
}
/***
* 是否为正整数
*/
public static boolean isPositiveInteger(double value) {
long a = (long) value;
if (a != value || a < 0) {
return false;
}
return true;
}
/***
* 是否为正整数
*/
public static boolean isPositiveInteger(String value) {
double d = Double.parseDouble(value);
long a = (long) d;
if (a != d || a < 0) {
return false;
}
return true;
}
}
分享到:
相关推荐
例如,如果源单位是“米”(m),目标单位是“厘米”(cm),则转换公式为`value_cm = value_m * 100`。将计算结果显示在ResultActivity的TextView上。 7. 更新UI展示结果 将转换后的结果设置到TextView中,以便...
3. **计算利息(calculateInterest)**:创建一个方法`double calculateInterest()`,根据设定的本金和年利率,使用上述公式计算利息。 4. **设定存款期限(tenure)**:创建`void setTenure(int years)`,用于设置...
public static double distanceLongLat(double longitudeA, double longitudeB, double latitudeA, double latitudeB) { double longA = longitudeA * Math.PI / 180; double longB = longitudeB * Math.PI / ...
- `double jtohudu(int *du, int *fen, float *miao)`:将角度值转换为弧度值,利用公式 `弧度 = 角度 / 180.0 * PI`。 - `struct angle dtoj(double *du)`:将弧度值转换为度、分、秒的结构体形式。 6. **内存...
对于温度和压力的换算,我们可以编写两个函数:`GetPressureFromTemperature(double temperature)` 和 `GetTemperatureFromPressure(double pressure)`。 在`GetPressureFromTemperature`函数中,我们将遍历温度-...
在`main`函数中,我们定义了两个`double`类型的变量,分别存储开氏度和摄氏度的值。然后,我们通过`cin`从用户那里获取开氏度的输入,并用`cerr`来处理错误情况,如开氏度小于或等于0时。接着,根据转换公式计算摄氏...
Private Function bl2xy(ByVal a2 As Double, ByVal f2 As Double, ByVal e2 As Double) As Boolean ' 计算带号n Dim n2 As Integer = Int(f2 / 6) + 1 ' 中央子午线l0 Dim l0 As Double = n2 * 6 - 3 ' 其他...
例如,对于一个4000米分辨率的RAW文件(2748*2748像素,数据类型为Double),我们可以通过ENVI的“Edit ENVI Header”工具来打开并设置这些参数。接着,通过ENVI主菜单的“Open”选项,我们可以加载RAW文件,确保...
double celsius = Convert.ToDouble(Console.ReadLine()); double fahrenheit = CelsiusToFahrenheit(celsius); Console.WriteLine($"转换后的华氏温度为: {fahrenheit:F2}"); Console.WriteLine("按任意键退出....
1. **数据类型**: `double` 类型用于表示实数。 2. **输入输出**: 使用 `Scanner` 类从控制台读取用户的输入。 3. **算术运算**: 应用数学公式进行简单的算术运算。 4. **控制台输出**: 使用 `System.out.println()`...
- **数据类型**: 使用了`double`类型来存储摄氏温度和华氏温度。 - **输入输出**: 使用`java.util.Scanner`类从控制台读取用户输入,并打印输出结果。 - **算术运算**: 使用了基本的算术运算符(乘法*、加法+)进行...
- **数据类型:** 使用`double`类型存储浮点数值。 ### 3. 函数重复调用 (ex2.3) **代码示例:** ```cpp #include void mice(); void see(); using namespace std; int main(){ mice(); mice(); see(); see();...
在这个案例中,程序首先提示用户输入圆的半径,并使用`double`类型来存储可能为小数的半径值。随后,程序通过简单的数学公式计算圆的面积和周长,并输出结果。这个案例不仅让学习者了解了如何使用`const`关键字来...
如果你想转换为其他单位,只需进行相应的换算。 在实际应用中,为了提高效率和用户体验,通常还会涉及到缓存位置数据、使用网络定位(如Google Play服务的FusedLocationProviderClient)等技术。此外,对于路径搜索...
1. **C#基础语法**:源码中会涉及到C#的基本数据类型(如int、double)、变量声明、条件语句(if-else)和控制流程(for、while)等,这些都是编写任何C#程序的基础。 2. **Windows Forms**:作为UI(用户界面)...
- **类型转换**:由于单位转换涉及到不同的数值类型,因此可能需要进行类型转换,例如 `int inches = (int) (lengthInMeters * 39.3701);` - **运算符**:使用乘法(*)和除法(/)运算符进行计算。 4. **方法...
2. **数据类型:** 使用`double`数据类型存储浮点数。 3. **变量声明与赋值:** 如何声明变量和通过算术运算进行赋值。 4. **算术运算:** 理解乘法运算符`*`的作用。 --- ##### PE2-3: 打印诗歌 **代码解释:** 此段...
在VB.NET编程中,经常会遇到需要进行角度单位之间的转换,比如弧度与度、度与度分秒之间的换算。这些转换在工程计算、地理坐标处理或者图形绘制等领域尤为重要。本篇文章将详细讲解如何在VB.NET中实现这些转换。 ...
2. 方法返回类型:给定的方法定义中,返回类型是将一个byte和double相除并乘以2的结果,由于计算过程中会涉及到浮点数运算,所以返回类型应该是double。 3. 数据流图(DFD):DFD是需求分析阶段常用的工具,用于...