Java封装了一个自适应的单位转换工具类

目录

前言

1、前期准备

2、实现代码

2.1 方法一:通过map去标记需要转换的 类属性字段

2.2 方法二:配合自定义注解


前言

平时在做项目中,经常会做一些数据书籍,尤其像是数据看板之类,需要从数据库中查询想要的数据,但这些数据的单位往往与需求是不匹配的。

比如,数据库中查询的金额是元,但页面上需要展示万元;

亦或是,数据库中查出的距离是米,业务需要的是千米;

又比如,需要将查出的数据除以100,返回前端做百分比展示。等等。。。。。。

那像这种情况,我们是怎么处理的呢?

很多时候我们拿到的是一个数据集合list,然后去遍历集合获取每个参数,再根据参数的属性去做相关的单位转换处理。然后一直重复做着get set,get set,get set。

像这样:

虽然这种写法不会报错,但是看着重复的get set方法,着实是有点孬。所以就封装了一个单位转换的工具类,请看正文。


1、前期准备

  • 接收数据的实体类:
import lombok.Data;import java.io.Serializable;
import java.math.BigDecimal;/*** 单位转换Vo*/
@Data
public class UnitConvertVo implements Serializable {private static final long serialVersionUID = 4784820539438132009L;/*** 日销售额(千元)*/private BigDecimal dailySales;/*** 年销售额(万元)*/private BigDecimal annualSales;/*** 营收占比(百分比)*/private BigDecimal percentage;/*** 营收占比(千分比)*/private BigDecimal perMillage;/*** 距离*/private BigDecimal distance;/*** 重量*/private BigDecimal weight;}
  • 定义单位类型枚举类

/*** 单位转换枚举*/
public enum UnitEnum {/*** 千元*/THOUSAND_YUAN("1", "千元"),/*** 万元*/TEN_THOUSAND_YUAN("2", "万元"),/*** 百分比*/PERCENTAGE("3", "百分比"),/*** 千分比*/PER_MILLAGE("4", "千分比"),/*** 米*/METER("5", "米"),/*** 千米*/KILOMETRE("6", "千米"),/*** 千克*/KILOGRAM("8", "千克"),/*** 吨*/TON("9", "吨");private final String code;private final String name;UnitEnum(String code, String name) {this.code = code;this.name = name;}public String getCode() {return code;}public String getName() {return name;}
}

2、实现代码

提供两种方法实现:

2.1 方法一:通过map去标记需要转换的 类属性字段

思路

1.通过反射取出字段
2.配合传入的转换标记Map,匹配哪些字段需要转换
3.然后从Map中取出相关字段的具体操作有哪些,然后执行转换
4.重新赋值

核心工具类:

import com.test.java.base.UnitEnum;
import lombok.extern.slf4j.Slf4j;import java.lang.reflect.Field;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.util.List;
import java.util.Map;/*** 单位转换工具类*/
@Slf4j
public class UnitConvertUtil {/*** 方法一:通过反射,获取标识map进行转换*/public static <T> void unitMapConvert(List<T> list, Map<String, UnitEnum> propertyMap) {for (T t : list) {Field[] declaredFields = t.getClass().getDeclaredFields();for (Field declaredField : declaredFields) {// 匹配map里的字段属性和转换操作if (propertyMap.keySet().stream().anyMatch(x -> x.equals(declaredField.getName()))) {try {declaredField.setAccessible(true);Object object = declaredField.get(t);UnitEnum unitEnum = propertyMap.get(declaredField.getName());if (object != null) {// 若匹配上,则执行对应的转换操作(加减乘除)// 元 → 千元if (unitEnum.equals(UnitEnum.THOUSAND_YUAN)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("1000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 元 → 万元if (unitEnum.equals(UnitEnum.TEN_THOUSAND_YUAN)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("10000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 百分比if (unitEnum.equals(UnitEnum.PERCENTAGE)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("100")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 千分比if (unitEnum.equals(UnitEnum.PER_MILLAGE)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("1000")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 千米 → 米if (unitEnum.equals(UnitEnum.METER)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("1000")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 米 → 千米if (unitEnum.equals(UnitEnum.KILOMETRE)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("1000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 吨 → 千克if (unitEnum.equals(UnitEnum.KILOGRAM)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("1000")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 千克 → 吨if (unitEnum.equals(UnitEnum.TON)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("1000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}}} catch (Exception e) {log.error("单位转换失败,{}", e.getMessage());}}}}}}

写个测试main方法:

    public static void main(String[] args) {// 创建测试数据UnitConvertVo vo = new UnitConvertVo();vo.setDailySales(new BigDecimal("23600.53"));vo.setAnnualSales(new BigDecimal("368624.24"));vo.setPercentage(new BigDecimal("0.2361"));vo.setPerMillage(new BigDecimal("0.536285"));vo.setDistance(new BigDecimal("8568.54"));// 米 → 千米vo.setWeight(new BigDecimal("35.62638"));// 吨 → 千克List<UnitConvertVo> list1 = new ArrayList<>();list1.add(vo);// 测试方法一:Map<String, UnitEnum> map = new HashMap<>();map.put("dailySales", UnitEnum.THOUSAND_YUAN);map.put("annualSales", UnitEnum.TEN_THOUSAND_YUAN);map.put("percentage", UnitEnum.PERCENTAGE);map.put("perMillage", UnitEnum.PER_MILLAGE);map.put("distance", UnitEnum.KILOMETRE);map.put("weight", UnitEnum.KILOGRAM);System.out.println("转换前:" + list1);unitMapConvert(list1, map);System.out.println("通过map标识转换:" + list1);}

转换结果:

2.2 方法二:配合自定义注解

其实第一种方法已经够用了,但是为了调用更加的方便,后期能够更好的拓展,所以配合着自定义注解,优化了一下,直接上代码:

  • 定义自定义注解
package com.test.java.annotation;import com.test.java.base.UnitEnum;import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;/*** 单位转换 自定义注解*/
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface UnitConvert {UnitEnum name();}
  • 在实体类上,使用自定义注解

import com.test.java.annotation.UnitConvert;
import com.test.java.base.UnitEnum;
import lombok.Data;import java.io.Serializable;
import java.math.BigDecimal;/*** 单位转换Vo*/
@Data
public class UnitConvertVo implements Serializable {private static final long serialVersionUID = 4784820539438132009L;/*** 日销售额(千元)*/@UnitConvert(name = UnitEnum.THOUSAND_YUAN)private BigDecimal dailySales;/*** 年销售额(万元)*/@UnitConvert(name = UnitEnum.TEN_THOUSAND_YUAN)private BigDecimal annualSales;/*** 营收占比(百分比)*/@UnitConvert(name = UnitEnum.PERCENTAGE)private BigDecimal percentage;/*** 营收占比(千分比)*/@UnitConvert(name = UnitEnum.PER_MILLAGE)private BigDecimal perMillage;/*** 距离*/@UnitConvert(name = UnitEnum.METER)private BigDecimal distance;/*** 重量*/@UnitConvert(name = UnitEnum.TON)private BigDecimal weight;}

配合自定义注解,在刚刚的工具类里又封装了一个方法,反射获取属性字段,解析注解,做对应转换操作。

import com.test.java.annotation.UnitConvert;
import com.test.java.base.UnitEnum;
import com.test.java.domain.vo.UnitConvertVo;
import lombok.extern.slf4j.Slf4j;import java.lang.reflect.Field;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.util.*;/*** 单位转换工具类*/
@Slf4j
public class UnitConvertUtil {/*** 方法一:通过反射,获取标识map进行转换*/public static <T> void unitMapConvert(List<T> list, Map<String, UnitEnum> propertyMap) {for (T t : list) {Field[] declaredFields = t.getClass().getDeclaredFields();for (Field declaredField : declaredFields) {// 匹配map里的字段属性和转换操作if (propertyMap.keySet().stream().anyMatch(x -> x.equals(declaredField.getName()))) {try {declaredField.setAccessible(true);Object object = declaredField.get(t);UnitEnum unitEnum = propertyMap.get(declaredField.getName());if (object != null) {// 若匹配上,则执行对应的转换操作(加减乘除)// 元 → 千元if (unitEnum.equals(UnitEnum.THOUSAND_YUAN)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("1000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 元 → 万元if (unitEnum.equals(UnitEnum.TEN_THOUSAND_YUAN)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("10000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 百分比if (unitEnum.equals(UnitEnum.PERCENTAGE)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("100")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 千分比if (unitEnum.equals(UnitEnum.PER_MILLAGE)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("1000")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 千米 → 米if (unitEnum.equals(UnitEnum.METER)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("1000")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 米 → 千米if (unitEnum.equals(UnitEnum.KILOMETRE)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("1000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 吨 → 千克if (unitEnum.equals(UnitEnum.KILOGRAM)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("1000")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 千克 → 吨if (unitEnum.equals(UnitEnum.TON)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("1000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}}} catch (Exception e) {log.error("单位转换失败,{}", e.getMessage());}}}}}/*** 方法二:通过自定义注解 进行转换*/public static <T> void unitAnnotationConvert(List<T> list) {for (T t : list) {// 获取属性字段Field[] declaredFields = t.getClass().getDeclaredFields();for (Field declaredField : declaredFields) {try {if ("serialVersionUID".equals(declaredField.getName())) {continue;}// 取出字段上的自定义注解UnitConvert myFieldAnn = declaredField.getAnnotation(UnitConvert.class);if (Objects.isNull(myFieldAnn)) {continue;}// 取出注解里面的转换类型枚举UnitEnum unitEnum = myFieldAnn.name();// 赋予超级权限declaredField.setAccessible(true);Object object = declaredField.get(t);if (Objects.nonNull(object)) {// 执行对应的转换操作(加减乘除)// 元 → 千元if (unitEnum.equals(UnitEnum.THOUSAND_YUAN)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("1000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 元 → 万元if (unitEnum.equals(UnitEnum.TEN_THOUSAND_YUAN)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("10000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 百分比if (unitEnum.equals(UnitEnum.PERCENTAGE)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("100")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 千分比if (unitEnum.equals(UnitEnum.PER_MILLAGE)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("1000")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 千米 → 米if (unitEnum.equals(UnitEnum.METER)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("1000")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 米 → 千米if (unitEnum.equals(UnitEnum.KILOMETRE)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("1000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 吨 → 千克if (unitEnum.equals(UnitEnum.KILOGRAM)) {BigDecimal bigDecimal = ((BigDecimal) object).multiply(new BigDecimal("1000")).setScale(2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}// 千克 → 吨if (unitEnum.equals(UnitEnum.TON)) {BigDecimal bigDecimal = ((BigDecimal) object).divide(new BigDecimal("1000"), 2, RoundingMode.HALF_UP);declaredField.set(t, bigDecimal);}}} catch (Exception e) {log.error("单位转换失败,{}", e.getMessage());}}}}public static void main(String[] args) {// 创建测试数据UnitConvertVo vo = new UnitConvertVo();vo.setDailySales(new BigDecimal("23600.53"));vo.setAnnualSales(new BigDecimal("368624.24"));vo.setPercentage(new BigDecimal("0.2361"));vo.setPerMillage(new BigDecimal("0.536285"));vo.setDistance(new BigDecimal("8568.54"));// 米 → 千米vo.setWeight(new BigDecimal("35.62638"));// 吨 → 千克UnitConvertVo vo1 = new UnitConvertVo();vo1.setDailySales(new BigDecimal("23600.53"));vo1.setAnnualSales(new BigDecimal("368624.24"));vo1.setPercentage(new BigDecimal("0.2361"));vo1.setPerMillage(new BigDecimal("0.536285"));vo1.setDistance(new BigDecimal("8.56854"));// 千米 → 米vo1.setWeight(new BigDecimal("35626.38"));// 千克 → 吨List<UnitConvertVo> list1 = new ArrayList<>();List<UnitConvertVo> list2 = new ArrayList<>();list1.add(vo);list2.add(vo1);// 测试方法一:Map<String, UnitEnum> map = new HashMap<>();map.put("dailySales", UnitEnum.THOUSAND_YUAN);map.put("annualSales", UnitEnum.TEN_THOUSAND_YUAN);map.put("percentage", UnitEnum.PERCENTAGE);map.put("perMillage", UnitEnum.PER_MILLAGE);map.put("distance", UnitEnum.KILOMETRE);map.put("weight", UnitEnum.KILOGRAM);System.out.println("转换前:" + list1);unitMapConvert(list1, map);System.out.println("通过map标识转换:" + list1);// 测试方法二:System.out.println("转换前:" + list2);unitAnnotationConvert(list2);System.out.println("通过注解标识转换:" + list2);}}

结果:

两种方法都正确的转换了单位,不过我个人推荐第二种方法,方便后期维护。

如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、评论、收藏➕关注,您的支持是我坚持写作最大的动力。  

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/616968.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

评论转换输出 - 华为OD统一考试

OD统一考试 分值&#xff1a; 200分 题解&#xff1a; Java / Python / C 题目描述 在一个博客网站上&#xff0c;每篇博客都有评论。每一条评论都是一个非空英文字母字符串。 评论具有树状结构&#xff0c;除了根评论外&#xff0c;每个评论都有一个父评论。当评论保存时&am…

环信服务端下载消息文件---菜鸟教程

前言 在服务端&#xff0c;下载消息文件是一个重要的功能。它允许您从服务器端获取并保存聊天消息、文件等数据&#xff0c;以便在本地进行进一步的处理和分析。本指南将指导您完成环信服务端下载消息文件的步骤。 环信服务端下载消息文件是指在环信服务端上&#xff0c;通过调…

重学Java 1.学习路线及相关概述

别灰心&#xff0c;好运会降临 ——24.1.11 Ss.1 学习框架图 Ss.2 硬件和软件 硬件是看得见、摸得着的物理部件或设备 软件是以程序和文档的形式存在 硬件和软件是相辅相成的&#xff0c;谁也离不开谁 Ss.3 计算机语言 计算机编程语言&#xff0c;就是人们对计算机下达的命令&a…

Linux集锦大全【持续更新】

文章目录 Linux集锦大全【持续更新】Linux最常用的几个归档和压缩命令解压方法之一 tar语法压缩文件查看压缩文件的内容解压文件 解压方法之一 zip语法参数参考实例仅保存文件名 解压命令之一 unzip基本命令指定目录解压不解压某些文件 解压命令之一 gzip Linux最危险的几个命令…

OpenGL学习笔记-Blending

混合方程中&#xff0c;Csource是片段着色器输出的颜色向量&#xff08;the color output of the fragment shader&#xff09;&#xff0c;其权重为Fsource。Cdestination是当前存储在color buffer中的颜色向量&#xff08;the color vector that is currently stored in the …

NAND Separate Command Address (SCA) 接口命令解读

CA output packet和CA input packet是Separate Command Address (SCA) NAND接口协议中用于命令和地址传输的关键数据结构。 CA Input Packet: 在SCA接口中&#xff0c;输入到NAND器件的命令和地址信息被组织成并行至串行转换的CA&#xff08;Command and Address&#xff09;输…

List列表操作中的坑

使用 Arrays.asList 把数据转换为 List 的三个坑 在如下代码中&#xff0c;我们初始化三个数字的 int[]数组&#xff0c;然后使用 Arrays.asList 把数组转换为 List&#xff1a; int[] arr {1, 2, 3}; List list Arrays.asList(arr); log.info("list:{} size:{} class…

服务器应用相关代码

1&#xff1a;建立基本网络服务器 我们的ESP866-NodeMCU虽然也能实现网络服务器的一些功能&#xff0c;但是毕竟它的运算能力是无法与那些昂贵的服务器电脑相媲美的&#xff0c;因此ESP8266-NodeMCU只能实现一些基本的网络服务功能。网络服务是一个很宽泛的概念&#xff0c;我…

HCIA的交换机(单臂路由)

实现单臂路由的IP自动分配 实验素材&#xff1a; 实现思路&#xff1a; 交换机&#xff1a;创建VLAN10&#xff0c;VLAN20&#xff0c;将0/0/1&#xff0c;2划入相应VLAN&#xff0c;接口使用access模式&#xff0c; 要实现两个交换机之间的通信&#xff0c;须在0/0/3口使用t…

MC-4/11/01/400具有精度高一倍和低速运行时振动较小的优点

MC-4/11/01/400具有精度高一倍和低速运行时振动较小的优点 MC-4/11/01/400具有精度高一倍和低速运行时振动较小的优点 整步驱动模式&#xff1a;在整步驱动模式中&#xff0c;步进电机控制器按照脉冲方向指令对两相步进电机的两个线圈进行循环激磁。每个脉冲会使电机移动一个…

知乎x-zse-96算法分析

声明 本文以教学为基准、本文提供的可操作性不得用于任何商业用途和违法违规场景。 本人对任何原因在使用本人中提供的代码和策略时可能对用户自己或他人造成的任何形式的损失和伤害不承担责任。 如有侵权,请联系我进行删除。 这里只是我分析过程,以及一些重要点的记录,没有…

YOLOv5改进系列(25)——添加LSKNet注意力机制(大选择性卷积核的领域首次探索)

【YOLOv5改进系列】前期回顾: YOLOv5改进系列(0)——重要性能指标与训练结果评价及分析 YOLOv5改进系列(1)——添加SE注意力机制 YOLOv5改进系

ES高级查询

ES中提供了一种强大的检索数据方式&#xff0c;这种检索方式称为Query DSL&#xff0c;这种方式的丰富查询语法让ES检索变得更强大&#xff0c;更简洁。 1.常见查询 1.1查询所有[match_all] match_all关键字&#xff1a;返回索引中的全部文档。 GET /products/_search { &…

【MFC实践】基于MFC向导C++制作计算器(附文件)

一、写在前面1.1 什么是MFC向导&#xff1f;1.2 使用MFC向导制作计算器1.3安装visual studio 2022和MFC插件 二、设计计算器界面1.1 新创建MFC项目1.2 设计计算器界面1.3 添加相关变量1.4 算法的一些问题及解决方式1.5 计算功能的实现1.6 其它功能的实现1.6.1 DEL功能1.6.2 C置…

关于白盒测试,这些技巧你得游刃有余~

对于很多刚开始学习软件测试的小伙伴来说&#xff0c;如果能尽早将黑盒、白盒测试弄明白&#xff0c;掌握两种测试的结论和基本原理&#xff0c;将对自己后期的学习有较好的帮助。今天&#xff0c;我们就来聊聊黑盒、白盒测试的相关话题。 1、黑盒测试的方法和小结 最常见黑盒…

C++标准学习--多线程

在以往多线程的实现的时候&#xff0c;都是自己去亲自创建线程&#xff0c;采用特殊flag 及锁控制线程的运转状态。这无可厚非&#xff0c;但又似乎有重复造轮子的嫌疑。最近发现了一个线程池的轮子&#xff0c;很不错&#xff0c;ZZ一下。 C多线程线程池&#xff08;全详解&a…

免费学习鸿蒙(HarmonyOS)开发,一些地址分享

HarmonyOS万物互联&#xff0c;从华为一系列的操作来看已经与iOS、Android形成三足鼎立之势了。 根据《澎湃新闻》的报道&#xff0c;已有23所985高校和46所211高校加入了鸿蒙班的行列&#xff0c;合计达到了69所国内一流高校。通过鸿蒙班的设立&#xff0c;高校可以为学生提供…

【Java】正则表达式( Pattern 和 Matcher 类)

快速入门 Java 提供了 java.util.regex 包&#xff0c;它包含了 Pattern 和 Matcher 类&#xff0c;用于处理正则表达式的匹配操作。 java.util.regex 包主要包括以下三个类&#xff1a; Pattern 类&#xff1a; pattern 对象是一个正则表达式的编译表示。Pattern 类没有公共…

从Scroll怒喷社区用户事件,看L2龙头ZKFair的做事格局

这两天&#xff0c;随着美国SEC正式批准所有11只比特币现货ETF的消息公布&#xff0c;吸引了传统主流增量资金的入场&#xff0c;比特币多头一举将比特币干到了48000刀的位置&#xff0c;并随时向着前高发起了冲击。比特币的强势带动了其他加密资产的保障&#xff0c;整个加密市…

面试常见问题回答干货

1、请你自我介绍一下你自己&#xff1f; 回答提示&#xff1a;一般人回答这个问题过于平常&#xff0c;只说姓名、年龄、爱好、工作经验&#xff0c;这些在简历上都有。其实&#xff0c;企业最希望知道的是求职者能否胜任工作&#xff0c;包括&#xff1a;最强的技能、最深入研…