BigDecimal类型用于面积换算

2024-06-06 18:20

本文主要是介绍BigDecimal类型用于面积换算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

案例:

BigDecimal numSum=new BigDecimal("0");//建筑总面积是0BuildInfo buildInfo=new BuildInfo();
buildInfo.setBuildArea(new BigDecimal("12"));//BigDecimal类型 面积为12
buildInfo.setAreaUnit("0004");//面积单位 0004目前代表 平方千米BigDecimal buildArea = IprmisUtils.convertArea(buildInfo.getBuildArea(), buildInfo.getAreaUnit(), "0001");//自然幢面积和面积单位进行转换 拿到自然幢平方米的真实面积
numSum=numSum.add(buildArea);//相加 0+转换后为平方米的面积

工具类:


public class IprmisUtils {/*** 返回实体的所有非 null 字段*/public static String[] getNotNullPropertyNames(Object source) {final BeanWrapper src = new BeanWrapperImpl(source);java.beans.PropertyDescriptor[] pds = src.getPropertyDescriptors();Set<String> notEmptyNames = new HashSet<>();for (java.beans.PropertyDescriptor pd : pds) {Object srcValue = src.getPropertyValue(pd.getName());if (srcValue != null){notEmptyNames.add(pd.getName());}}String[] result = new String[notEmptyNames.size()];return notEmptyNames.toArray(result);}/*** 返回实体的所有 null 字段*/public static String[] getNullPropertyNames(Object source) {final BeanWrapper src = new BeanWrapperImpl(source);java.beans.PropertyDescriptor[] pds = src.getPropertyDescriptors();Set<String> emptyNames = new HashSet<>();for (java.beans.PropertyDescriptor pd : pds) {Object srcValue = src.getPropertyValue(pd.getName());if (srcValue == null){emptyNames.add(pd.getName());}}String[] result = new String[emptyNames.size()];return emptyNames.toArray(result);}/*** 面积单位转换* @param area 面积* @param fromUnit 传入面积单位 "0001"平方米、"0002"亩、"0003"公顷、"0004"平方千米(默认"0001"平方米)* @param toUnit 输出面积单位 "0001"平方米、"0002"亩、"0003"公顷、"0004"平方千米* @return 转换后面积*/public static BigDecimal convertArea(BigDecimal area, String fromUnit, String toUnit) {if(area==null){return null;}if (StrUtil.isBlank(fromUnit)){fromUnit = "0001";}if (fromUnit.equals(toUnit)){return area;}// 将所有单位转换为平方米double area1 = area.doubleValue();double squareMeters;switch (fromUnit) {//平方千米case "0004":squareMeters = area1 * 1000000;break;//公顷case "0003":squareMeters = area1 * 10000;break;//亩case "0002":squareMeters = area1 * 666.667;break;//case "0001": //平方米//平方米default:squareMeters = area1;}// 将平方米转换为目标单位double convertedArea;switch (toUnit) {case "0001": //平方米convertedArea = squareMeters;break;case "0004": //平方千米convertedArea = squareMeters / 1000000;break;case "0003": //公顷convertedArea = squareMeters / 10000;break;case "0002": //亩convertedArea = squareMeters / 666.667;break;default:throw new BusinessException("输出面积单位错误!");}return BigDecimal.valueOf(convertedArea);}/*** 金额单位转换* @param amount 金额* @param fromUnit 传入金额单位 "0001"元、"0002"万元(传入不在限定值或空默认元)* @param toUnit  输出金额单位 "0001"元、"0002"万元* @return 转换后金额*/public static BigDecimal convertAmount(BigDecimal amount, String fromUnit, String toUnit) {if(amount==null){return null;}if (StrUtil.isBlank(fromUnit)){fromUnit = "0001";}if(fromUnit.equals(toUnit)){return amount;}// 先将输入的金额统一转换为元double amount1 = amount.doubleValue();double yuan;// 万元if ("0002".equalsIgnoreCase(fromUnit)) {yuan = amount1 * 10000;//case "0001": // 元// 元} else {yuan = amount1;}// 根据目标金额单位进行转换double convertedAmount;switch (toUnit.toLowerCase()) {// 元case "0001":convertedAmount = yuan;break;// 万元case "0002":convertedAmount = yuan / 10000;break;default:throw new BusinessException("输出金额单位错误!");}return BigDecimal.valueOf(convertedAmount);}/*** 格式化日期* @param date 需格式化日期* @param formatPattern 格式 不指定默认返回【yyyy-MM-dd】格式* @return 格式化后日期*/public static String formatDateToString(Date date, String formatPattern) {if(date==null){return null;}if(StrUtil.isBlank(formatPattern)){formatPattern="yyyy-MM-dd";}try {// 创建SimpleDateFormat对象,并指定日期格式SimpleDateFormat sdf = new SimpleDateFormat(formatPattern);// 使用format()方法将日期对象格式化为字符串并返回return sdf.format(date);} catch (IllegalArgumentException e) {return null;}}/*** 对象属性赋值批量操作* @param listA 源数据list* @param listB 操作源list* @param primaryKey 关联主键* @param excludedProperties 排除的字段* @param <T> 泛型A* @param <U> 泛型B*/public static <T, U> void updateListB(List<T> listA, List<U> listB,String primaryKey, String... excludedProperties) {for (T t : listA) {for (U u : listB) {if (ObjectUtil.equals(getFieldValue(t,primaryKey),getFieldValue(u,primaryKey))){BeanUtils.copyProperties(t, u, excludedProperties);}}}}/*** 反射获取泛型的对应字段的值* @param obj 泛型对象* @param fieldName 属性名称* @param <T> 泛型* @return 属性值*/public static <T> Object getFieldValue(T obj, String fieldName) {Class<?> clazz = obj.getClass();try {Field field = clazz.getDeclaredField(fieldName);field.setAccessible(true);return field.get(obj);} catch (NoSuchFieldException | IllegalAccessException e) {e.printStackTrace();}return null;}
}

这篇关于BigDecimal类型用于面积换算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1036877

相关文章

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

Mysql BLOB类型介绍

BLOB类型的字段用于存储二进制数据 在MySQL中,BLOB类型,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储的大小不同。 TinyBlob 最大 255 Blob 最大 65K MediumBlob 最大 16M LongBlob 最大 4G

Oracle type (自定义类型的使用)

oracle - type   type定义: oracle中自定义数据类型 oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式, 如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型 格式 :create or repla

MyBatis 切换不同的类型数据库方案

下属案例例当前结合SpringBoot 配置进行讲解。 背景: 实现一个工程里面在部署阶段支持切换不同类型数据库支持。 方案一 数据源配置 关键代码(是什么数据库,该怎么配就怎么配) spring:datasource:name: test# 使用druid数据源type: com.alibaba.druid.pool.DruidDataSource# @需要修改 数据库连接及驱动u

按揭贷款类型

按揭贷款可以根据不同的分类标准分为多种类型。以下是按揭贷款的一些常见分类: 按贷款利率分类: 固定利率按揭(Fixed Rate Mortgage, FRM):在整个贷款期间,利率保持不变,这意味着每月还款额也是固定的。浮动利率按揭(Adjustable Rate Mortgage, ARM):贷款利率随市场利率的变化而调整,通常有一个基准利率加上一定的浮动点数。 按还款方式分类: 等额本息(

PHP7扩展开发之类型处理

前言 这次,我们将演示如何在PHP扩展中如何对类型进行一些操作。如,判断变量类型。要实现的PHP代码如下: <?phpfunction get_size ($value) {if (is_string($value)) {return "string size is ". strlen($value);} else if (is_array($value)) {return "array si