持续总结中!2024年面试必问 100 道 Java基础面试题(四十)

2024-05-11 06:12

本文主要是介绍持续总结中!2024年面试必问 100 道 Java基础面试题(四十),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一篇地址:持续总结中!2024年面试必问 100 道 Java基础面试题(三十九)-CSDN博客

七十九、Java泛型中的T、R、K、V、E分别指什么?

在Java泛型中,TRKVE 是类型参数的常见占位符,它们用来表示泛型类型中的类型变量。这些占位符通常用于泛型类、泛型接口或泛型方法的定义中,它们分别代表不同的类型,但在泛型的上下文中,它们是等价的,可以互换使用。以下是每个占位符的常见用法:

  1. T(Type)

    • T 是最常用的泛型类型参数占位符,代表任意类型。它通常用于表示泛型类或方法中的类型,可以是任何类或接口。
    public class GenericClass<T> {private T value;public GenericClass(T value) {this.value = value;}public T getValue() {return value;}
    }
  2. R(Return Type)

    • R 通常用于泛型方法的返回类型。它代表方法返回值的类型,这个类型可以由方法的泛型参数决定。
    public class UtilityClass {public static <R> R convertType(Object obj, Class<R> clazz) {// 转换obj到Class<R>指定的类型return null;}
    }
  3. KV

    • K 和 V 常用于表示键(Key)和值(Value)的类型,特别是在定义关联数组或映射(如 Map)时。
    public class Pair<K, V> {private final K key;private final V value;public Pair(K key, V value) {this.key = key;this.value = value;}// getters and other methods
    }
  4. E(Element)

    • E 通常用于表示元素类型,比如在定义一个可以存储任意类型元素的集合类时。
    public class ElementList<E> {private List<E> elements;public void addElement(E element) {elements.add(element);}// 其他方法
    }

这些泛型类型参数占位符的使用约定并非强制性的,它们只是常见的用法,目的是为了让代码更具可读性。开发者也可以使用其他任何有效的标识符作为泛型类型参数的名称,例如MyTypeInputTypeOutputType 等。

示例代码

public class Example<T, V> {private T id;private V name;public Example(T id, V name) {this.id = id;this.name = name;}public static <K, V> Map<K, V> createMap(K key, V value) {Map<K, V> map = new HashMap<>();map.put(key, value);return map;}public static void main(String[] args) {Example<Integer, String> example = new Example<>(1, "Example");Map<String, Integer> map = createMap("one", 1);}
}

在这个示例中,Example 类使用了 TV 作为泛型类型参数,而 createMap 静态方法使用了 KV 来创建一个 Map 对象。

总结来说,泛型类型参数的名称可以根据上下文和开发者的偏好来选择,关键是保持代码的清晰和一致性。

八十、Java金额计算怎么避免精度丢失?

在Java中进行金额计算时避免精度丢失是一个重要的考虑因素,因为错误的结果可能会导致财务错误或不准确的报告。以下是一些避免精度丢失的方法:

使用合适的数据类型

  1. BigDecimal

    • BigDecimal 类是Java提供的一个用于进行精确小数运算的类,它允许进行多精度的定点数运算,非常适合用于金额计算。
  2. doublefloat

    • double 和 float 类型是基于IEEE 754标准的浮点数,它们在表示非常大或非常小的数值时可能会有精度问题,因此不推荐用于精确的金额计算。

使用 BigDecimal 的最佳实践

  1. 避免使用构造器

    • 不推荐使用 BigDecimal 的构造器(如 BigDecimal(double))从 double 或 float 类型创建 BigDecimal 实例,因为这可能会引入初始的精度问题。
  2. 使用字符串构造器

    • 使用 BigDecimal(String) 构造器从字符串创建 BigDecimal 对象,这样可以确保数值的精确表示。
  3. 链式操作

    • 使用 BigDecimal 的链式方法调用,如 add()subtract()multiply() 和 divide() 等,来进行运算。
  4. 设置小数点后的位数

    • 在进行除法运算时,可以使用 setScale() 方法设置小数点后的位数和舍入模式。

示例代码

import java.math.BigDecimal;
import java.math.RoundingMode;public class MonetaryCalculation {public static void main(String[] args) {// 使用字符串构造BigDecimal对象BigDecimal amount1 = new BigDecimal("100.5");BigDecimal amount2 = new BigDecimal("2.5");// 进行加法和减法运算BigDecimal sum = amount1.add(amount2);BigDecimal difference = amount1.subtract(amount2);// 进行乘法和除法运算,并设置结果的小数点后位数BigDecimal product = amount1.multiply(amount2);BigDecimal quotient = amount1.divide(amount2, 2, RoundingMode.HALF_UP);System.out.println("Sum: " + sum);System.out.println("Difference: " + difference);System.out.println("Product: " + product);System.out.println("Quotient: " + quotient);}
}

在这个示例中,我们使用 BigDecimal 类进行了金额的加法、减法、乘法和除法运算。注意,我们使用字符串构造器创建 BigDecimal 对象,并在除法运算后设置了小数点后的位数和舍入模式。

注意事项

  • 避免类型转换:在进行金额计算时,避免将 BigDecimal 转换为 double 或 float 类型。
  • 舍入模式:在设置小数点位数时,选择合适的舍入模式非常重要,如 RoundingMode.HALF_UP 是最常用的模式之一。
  • 维护精度:在设计财务系统时,始终保持足够的精度以避免舍入误差的累积。

总结来说,为了避免Java中的金额计算精度丢失,推荐使用 BigDecimal 类,并遵循最佳实践,如使用字符串构造器创建对象,链式调用运算方法,并在需要时设置小数点后的位数和舍入模式。

这篇关于持续总结中!2024年面试必问 100 道 Java基础面试题(四十)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法