Spring Boot 内置工具类
一、对象、数组、集合
ObjectUtils
1.获取对象的基本信息
// 获取对象的类名。参数为 null 时,返回字符串:"null"
String nullSafeClassName(Object obj)// 参数为 null 时,返回 0
int nullSafeHashCode(Object object)// 参数为 null 时,返回字符串:"null"
String nullSafeToString(boolean[] array)// 获取对象 HashCode(十六进制形式字符串)。参数为 null 时,返回 0
String getIdentityHexString(Object obj)// 获取对象的类名和 HashCode。 参数为 null 时,返回字符串:""
String identityToString(Object obj)// 相当于 toString()方法,但参数为 null 时,返回字符串:""
String getDisplayString(Object obj)
2.判断工具
// 判断数组是否为空
boolean isEmpty(Object[] array)// 判断参数对象是否是数组
boolean isArray(Object obj)// 判断数组中是否包含指定元素
boolean containsElement(Object[] array, Object element)// 相等,或同为 null时,返回 true
boolean nullSafeEquals(Object o1, Object o2)/*判断参数对象是否为空,判断标准为:Optional: Optional.empty()Array: length == 0CharSequence: length == 0Collection: Collection.isEmpty()Map: Map.isEmpty()*/
boolean isEmpty(Object obj)
3.其他工具方法
// 向参数数组的末尾追加新元素,并返回一个新数组
<A, O extends A> A[] addObjectToArray(A[] array, O obj)// 原生基础类型数组 --> 包装类数组
Object[] toObjectArray(Object source)
StringUtils
1.字符串判断工具
// 判断字符串是否为 null,或 ""。注意,包含空白符的字符串为非空
boolean isEmpty(Object str)// 判断字符串是否是以指定内容结束。忽略大小写
boolean endsWithIgnoreCase(String str, String suffix)// 判断字符串是否已指定内容开头。忽略大小写
boolean startsWithIgnoreCase(String str, String prefix) // 是否包含空白符
boolean containsWhitespace(String str)// 判断字符串非空且长度不为 0,即,Not Empty
boolean hasLength(CharSequence str)// 判断字符串是否包含实际内容,即非仅包含空白符,也就是 Not Blank
boolean hasText(CharSequence str)// 判断字符串指定索引处是否包含一个子串。
boolean substringMatch(CharSequence str, int index, CharSequence substring)// 计算一个字符串中指定子串的出现次数
int countOccurrencesOf(String str, String sub)
2.字符串操作工具
// 查找并替换指定子串
String replace(String inString, String oldPattern, String newPattern)// 去除尾部的特定字符
String trimTrailingCharacter(String str, char trailingCharacter) // 去除头部的特定字符
String trimLeadingCharacter(String str, char leadingCharacter)// 去除头部的空白符
String trimLeadingWhitespace(String str)// 去除头部的空白符
String trimTrailingWhitespace(String str)// 去除头部和尾部的空白符
String trimWhitespace(String str)// 删除开头、结尾和中间的空白符
String trimAllWhitespace(String str)// 删除指定子串
String delete(String inString, String pattern)// 删除指定字符(可以是多个)
String deleteAny(String inString, String charsToDelete)// 对数组的每一项执行 trim() 方法
String[] trimArrayElements(String[] array)// 将 URL 字符串进行解码
String uriDecode(String source, Charset charset)
3.路径相关工具方法
// 解析路径字符串,优化其中的 “..”
String cleanPath(String path)// 解析路径字符串,解析出文件名部分
String getFilename(String path)// 解析路径字符串,解析出文件后缀名
String getFilenameExtension(String path)// 比较两个两个字符串,判断是否是同一个路径。会自动处理路径中的 “..”
boolean pathEquals(String path1, String path2)// 删除文件路径名中的后缀部分
String stripFilenameExtension(String path) // 以 “. 作为分隔符,获取其最后一部分
String unqualify(String qualifiedName)// 以指定字符作为分隔符,获取其最后一部分
String unqualify(String qualifiedName, char separator)
CollectionUtils
1.集合判断工具
// 判断 List/Set 是否为空
boolean isEmpty(Collection<?> collection)// 判断 Map 是否为空
boolean isEmpty(Map<?,?> map)// 判断 List/Set 中是否包含某个对象
boolean containsInstance(Collection<?> collection, Object element)// 以迭代器的方式,判断 List/Set 中是否包含某个对象
boolean contains(Iterator<?> iterator, Object element)// 判断 List/Set 是否包含某些对象中的任意一个
boolean containsAny(Collection<?> source, Collection<?> candidates)// 判断 List/Set 中的每个元素是否唯一。即 List/Set 中不存在重复元素
boolean hasUniqueObject(Collection<?> collection)
2.集合操作工具
// 将 Array 中的元素都添加到 List/Set 中
<E> void mergeArrayIntoCollection(Object array, Collection<E> collection)// 将 Properties 中的键值对都添加到 Map 中
<K,V> void mergePropertiesIntoMap(Properties props, Map<K,V> map)// 返回 List 中最后一个元素
<T> T lastElement(List<T> list)// 返回 Set 中最后一个元素
<T> T lastElement(Set<T> set)// 返回参数 candidates 中第一个存在于参数 source 中的元素
<E> E findFirstMatch(Collection<?> source, Collection<E> candidates)// 返回 List/Set 中指定类型的元素。
<T> T findValueOfType(Collection<?> collection, Class<T> type)// 返回 List/Set 中指定类型的元素。如果第一种类型未找到,则查找第二种类型,以此类推
Object findValueOfType(Collection<?> collection, Class<?>[] types)// 返回 List/Set 中元素的类型
Class<?> findCommonElementType(Collection<?> collection)
二、断言
-
断言是一个逻辑判断,用于检查不应该发生的情况
-
Assert 关键字在 JDK1.4 中引入,可通过 JVM 参数
-enableassertions开启 -
SpringBoot 中提供了 Assert 断言工具类,通常用于数据合法性检查
// 要求参数 object 必须为非空(Not Null),否则抛出异常,不予放行
// 参数 message 参数用于定制异常信息。
void notNull(Object object, String message)// 要求参数必须空(Null),否则抛出异常,不予『放行』。
// 和 notNull() 方法断言规则相反
void isNull(Object object, String message)// 要求参数必须为真(True),否则抛出异常,不予『放行』。
void isTrue(boolean expression, String message)// 要求参数(List/Set)必须非空(Not Empty),否则抛出异常,不予放行
void notEmpty(Collection collection, String message)// 要求参数(String)必须有长度(即,Not Empty),否则抛出异常,不予放行
void hasLength(String text, String message)// 要求参数(String)必须有内容(即,Not Blank),否则抛出异常,不予放行
void hasText(String text, String message)// 要求参数是指定类型的实例,否则抛出异常,不予放行
void isInstanceOf(Class type, Object obj, String message)// 要求参数 `subType` 必须是参数 superType 的子类或实现类,否则抛出异常,不予放行
void isAssignable(Class superType, Class subType, String message)
三、文件、资源、IO 流
FileCopyUtils
1.输入
// 从文件中读入到字节数组中
byte[] copyToByteArray(File in)// 从输入流中读入到字节数组中
byte[] copyToByteArray(InputStream in)// 从输入流中读入到字符串中
String copyToString(Reader in)
2.输出
// 从字节数组到文件
void copy(byte[] in, File out)// 从文件到文件
int copy(File in, File out)// 从字节数组到输出流
void copy(byte[] in, OutputStream out) // 从输入流到输出流
int copy(InputStream in, OutputStream out) // 从输入流到输出流
int copy(Reader in, Writer out)// 从字符串到输出流
void copy(String in, Writer out)
ResourceUtils
1.从资源路径获取文件
// 判断字符串是否是一个合法的 URL 字符串。
static boolean isUrl(String resourceLocation)// 获取 URL
static URL getURL(String resourceLocation) // 获取文件(在 JAR 包内无法正常使用,需要是一个独立的文件)
static File getFile(String resourceLocation)
2.Resource
// 文件系统资源 D:\...
FileSystemResource// URL 资源,如 file://... http://...
UrlResource// 类路径下的资源,classpth:...
ClassPathResource// Web 容器上下文中的资源(jar 包、war 包)
ServletContextResource// 判断资源是否存在
boolean exists()// 从资源中获得 File 对象
File getFile()// 从资源中获得 URI 对象
URI getURI()// 从资源中获得 URI 对象
URL getURL()// 获得资源的 InputStream
InputStream getInputStream()// 获得资源的描述信息
String getDescription()
StreamUtils
1.输入
void copy(byte[] in, OutputStream out)int copy(InputStream in, OutputStream out)void copy(String in, Charset charset, OutputStream out)long copyRange(InputStream in, OutputStream out, long start, long end)
2.输出
byte[] copyToByteArray(InputStream in)String copyToString(InputStream in, Charset charset)// 舍弃输入流中的内容
int drain(InputStream in)
四、反射、AOP
ReflectionUtils
1.获取方法
// 在类中查找指定方法
Method findMethod(Class<?> clazz, String name) // 同上,额外提供方法参数类型作查找条件
Method findMethod(Class<?> clazz, String name, Class<?>... paramTypes) // 获得类中所有方法,包括继承而来的
Method[] getAllDeclaredMethods(Class<?> leafClass) // 在类中查找指定构造方法
Constructor<T> accessibleConstructor(Class<T> clazz, Class<?>... parameterTypes) // 是否是 equals() 方法
boolean isEqualsMethod(Method method) // 是否是 hashCode() 方法
boolean isHashCodeMethod(Method method) // 是否是 toString() 方法
boolean isToStringMethod(Method method) // 是否是从 Object 类继承而来的方法
boolean isObjectMethod(Method method) // 检查一个方法是否声明抛出指定异常
boolean declaresException(Method method, Class<?> exceptionType)
2.执行方法
// 执行方法
Object invokeMethod(Method method, Object target) // 同上,提供方法参数
Object invokeMethod(Method method, Object target, Object... args) // 取消 Java 权限检查。以便后续执行该私有方法
void makeAccessible(Method method) // 取消 Java 权限检查。以便后续执行私有构造方法
void makeAccessible(Constructor<?> ctor)
3.获取字段
// 在类中查找指定属性
Field findField(Class<?> clazz, String name) // 同上,多提供了属性的类型
Field findField(Class<?> clazz, String name, Class<?> type) // 是否为一个 "public static final" 属性
boolean isPublicStaticFinal(Field field)
4.设置字段
// 获取 target 对象的 field 属性值
Object getField(Field field, Object target) // 设置 target 对象的 field 属性值,值为 value
void setField(Field field, Object target, Object value) // 同类对象属性对等赋值
void shallowCopyFieldState(Object src, Object dest)// 取消 Java 的权限控制检查。以便后续读写该私有属性
void makeAccessible(Field field) // 对类的每个属性执行 callback
void doWithFields(Class<?> clazz, ReflectionUtils.FieldCallback fc) // 同上,多了个属性过滤功能。
void doWithFields(Class<?> clazz, ReflectionUtils.FieldCallback fc, ReflectionUtils.FieldFilter ff) // 同上,但不包括继承而来的属性
void doWithLocalFields(Class<?> clazz, ReflectionUtils.FieldCallback fc)
AopUtils
1.判断代理类型
// 判断是不是 Spring 代理对象
boolean isAopProxy()// 判断是不是 jdk 动态代理对象
isJdkDynamicProxy()// 判断是不是 CGLIB 代理对象
boolean isCglibProxy()
2.获取被代理对象的 class
// 获取被代理的目标 class
Class<?> getTargetClass()
AopContext
1.获取当前对象的代理对象
Object currentProxy()
相关文章:
Spring Boot 内置工具类
一、对象、数组、集合 ObjectUtils 1.获取对象的基本信息 // 获取对象的类名。参数为 null 时,返回字符串:"null" String nullSafeClassName(Object obj)// 参数为 null 时,返回 0 int nullSafeHashCode(Object object)// 参数…...
C语言--每日选择题--Day27
第一题 1. 对于代码段,问下面不可以表示a[1]地址的是() int a[10]; A:&a[0] 1 B:a sizeof(int) C:(int*)&a 1 D:(int*)((char*)&a sizeof(int)) 答案及解析 A A:取到…...
黑马程序员索引学习笔记
文章目录 索引的分类从索引字段特性从物理存储从数据结构组成索引的字段个数 InnoDB主键索的Btree高度为多高呢?explain执行计划最左匹配原则索引失效情况SQL提示覆盖索引、回表查询前缀索引索引设计原则 索引的分类 从索引字段特性 主键索引、唯一索引、常规索引、全文索引…...
新手如何对一个web网页进行一次渗透测试
新手如何对一个web网页进行一次渗透测试 文章目录 新手如何对一个web网页进行一次渗透测试什么是渗透测试?渗透测试和红蓝对抗的区别那么拿到一个网站后如何进行一次优雅的渗透测试呢 什么是渗透测试? 在获得web服务运营的公司书面授权的情况下,模拟攻击者的行为…...
vs2019 - MFC对话框程序的工程名称不支持下划线命名法
文章目录 vs2019 - MFC对话框程序的工程名称不支持下划线命名法概述笔记备注END vs2019 - MFC对话框程序的工程名称不支持下划线命名法 概述 正在写账单分析程序, 用MFC 对话框. 因为比较习惯下划线命名法, 就在向导中给工程名称起了一个my_test这样的名称(下划线命名法, 小…...
java JDBCUtils 使用静态代码块连接数据库 全程值保持一次连接
\src\com\data\entity\JDBCUtils.java 使用静态代码块连接数据库 全程值保持一次连接 package com.data.entity;import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.datasource.DriverManagerDataSource;import javax.sql.DataSource;pub…...
剑指 Offer(第2版)题解(C++ Version)
剑指 Offer(第2版)题解(C Version) 剑指 Offer(第2版)题解(C Version)面试题 3:数组中重复的数字面试题 4:二维数组中的查找面试题 5:替换空格面试…...
6.15合并二叉树(LC617-E)
算法: 前序、中序、后序都可以,这道题正常逻辑一般都是用前序 正确代码: 这里就是在root1这颗树上改的,也可以新建一个树。 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode …...
百度智能小程序系统源码+关键词排名优化 附带完整的搭建教程
百度智能小程序系统的开发背景是基于百度强大的技术实力和对用户需求的深入理解。在移动互联网时代,用户对便捷、高效、智能的服务需求越来越高。而小程序作为一种轻量级的应用程序,恰好能够满足用户的这些需求。然而,开发一个小程序需要掌握…...
2019年11月7日 Go生态洞察:Go Modules v2及更高版本
🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁 🦄 博客首页——🐅🐾猫头虎的博客🎐 🐳 《面试题大全专栏》 🦕 文章图文…...
vue3通过provide和inject实现多层级组件通信
父组件 <template><div><h1>我是父组件 {{num}}</h1><hr><child></child></div> </template><script setup> import child from ./child.vue; import { ref,provide } from vue; let num ref(520) provide(pare…...
【Java学习笔记】72 - 满汉楼 - 餐饮管理系统
项目代码 https://github.com/yinhai1114/Java_Learning_Code/tree/main/IDEA_Chapter26 一、需求说明 满汉楼项目功能多,界面复杂,涉及到复杂的awt和swing技术和事件编程,做如下调整: 1.去掉界面和事件处理(工作中使用很少),使…...
【我的创作纪念日】
机缘 大家好,我是圥忈ゼ, 2023 年 07 月 20 日,我撰写了第 1 篇技术博客:《我的编程未来规划》,也是由于我高考后的专业选择,和就业方向的选择,加上想立志成为一名专业 IT 作者,我结…...
车载通信架构 —— 传统车内通信网络MOST总线(光纤传输、专精多媒体)
车载通信架构 —— 传统车内通信网络MOST总线(光纤传输、专精多媒体) 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都…...
使用Pytorch从零开始构建Energy-based Model
知识回顾: [1] 生成式建模概述 [2] Transformer I,Transformer II [3] 变分自编码器 [4] 生成对抗网络,高级生成对抗网络 I,高级生成对抗网络 II [5] 自回归模型 [6] 归一化流模型 [7] 基于能量的模型 [8] 扩散模型 I, 扩散模型 II 在本教程中…...
基于C#实现梳排序
为什么取名为梳,可能每个梳都有自己的 gap 吧,大梳子 gap 大一点,小梳子 gap 小一点。上一篇我们看到鸡尾酒排序是在冒泡排序上做了一些优化,将单向的比较变成了双向,同样这里的梳排序也是在冒泡排序上做了一些优化。 …...
盘点72个Android系统源码安卓爱好者不容错过
盘点72个Android系统源码安卓爱好者不容错过 学习知识费力气,收集整理更不易。 知识付费甚欢喜,为咱码农谋福利。 链接:https://pan.baidu.com/s/1qiWeLjF2i4dlgmTYgPPSvw?pwd8888 提取码:8888 项目名称 A keyboardlisten…...
nodejs+vue+elementui足球篮球联赛系统
系统主要是以后台管理员管理为主。管理员需要先登录系统然后才可以使用本系统,管理员可以对个人中心、用户管理、赛事信息管理、球队信息管理、球员信息管理、比赛分值板管理、系统管理等进行添加、查询、修改、删除,以保障足球联赛管理系统的正常运行。…...
18.Oracle的过程和函数
oracle11g的过程和函数 一、过程(Procedure)1、子程序2、过程的相关语法 二、函数(Function)1、函数的概念2、函数的创建3、 案例 在Oracle数据库中,过程和函数都是用来封装一系列SQL语句和逻辑操作的数据库对象&#…...
A JSONObject text must begin with ‘{‘ at 1 [character 2 line 1]
今天调用一个接口,返回的是json数据,但是拿到数据进行转换的报错, JSONObject resultJson new JSONObject(resuStr);报错信息是: Exception in thread "main" org.json.JSONException: A JSONObject text must begin …...
ComfyUI翻译节点实战:一键将中文提示词精准转化为英文
1. ComfyUI翻译节点:中文用户的效率救星 每次用ComfyUI生成图片时,最头疼的就是写英文提示词。作为一个母语中文的用户,我经常要反复切换浏览器查词典、用翻译软件,好不容易凑出来的英文提示词还经常词不达意。直到发现了ComfyUI的…...
SAP PP实战:MRP Area怎么用?手把手教你按产线、委外供应商拆分物料计划
SAP PP实战:MRP Area精细化物料计划管理指南 引言 在制造业生产计划管理中,物料需求计划(MRP)的精确性直接影响着生产效率与成本控制。传统以工厂为单位的MRP运行模式往往难以应对复杂生产环境下的精细化需求——当多条产线并行运…...
SIEMENS 1FK6081-6AF71-1ZZ9-Z伺服电机
SIEMENS 1FK6081-6AF71-1ZZ9-Z 伺服电机SIEMENS 1FK6081-6AF71-1ZZ9-Z 是一款1FK6系列交流同步伺服电机,主要用于工业自动化与高精度运动控制系统,常见于数控机床、机器人及自动化生产设备中。属于1FK6系列同步伺服电机用于工业自动化运动控制系统提供高…...
Stable-Diffusion-v1-5-Archive 模型部署运维指南:监控、日志与故障排查
Stable-Diffusion-v1-5-Archive 模型部署运维指南:监控、日志与故障排查 部署好一个AI模型,就像把一台新机器开动起来,真正的挑战往往在后面。模型跑起来了,但它稳定吗?效率怎么样?出了问题怎么快速找到原…...
小马智行世界模型进化史,PonyWorld方案解析......
点击下方卡片,关注“自动驾驶之心”公众号戳我-> 领取自动驾驶近30个方向学习路线编辑 | 自动驾驶之心>>自动驾驶前沿信息获取→自动驾驶之心知识星球自从18年世界模型开始进入大众视野以来,已经逐渐烟花成“学习环境规律 — 推演未来 — 再优化…...
毫米波雷达DOA估计:从基础FFT到超分辨MUSIC,核心算法演进与实战选型指南
1. 毫米波雷达DOA估计基础入门 第一次接触毫米波雷达DOA估计时,我被各种专业术语搞得晕头转向。经过几个实际项目的打磨,我发现理解这个概念其实可以从一个生活场景开始:想象你在一个嘈杂的餐厅里,闭着眼睛也能判断出朋友在哪个方…...
WorkshopDL:5分钟掌握跨平台Steam创意工坊模组下载的终极方案
WorkshopDL:5分钟掌握跨平台Steam创意工坊模组下载的终极方案 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 你是否在Epic Games Store或GOG平台购买了游戏&#x…...
深入解析Neurosim芯片架构设计(二):从Tile到PE的层次化实现
1. Neurosim芯片的层次化架构全景 第一次看到Neurosim芯片的架构图时,那种感觉就像初次拆解俄罗斯套娃——从最外层的Chip Level开始,逐层打开Tile、PE、Sub-array这些精妙的层级结构。这种层次化设计可不是为了好看,而是实实在在解决了神经网…...
告别抓瞎:手把手教你用eBPF uprobe给Go/Python应用函数调用‘上监控’
深度实践:用eBPF uprobe实现Go/Python应用函数级监控 当线上服务出现性能瓶颈时,大多数开发者习惯用日志埋点或抽样 profiling 来定位问题。这种方法就像在黑暗房间里用手电筒找钥匙——效率低下且容易遗漏关键细节。而 eBPF 的 uprobe 技术相当于为整个…...
Word-MCP-Server进阶指南 | 在Cursor中打造智能Word自动化工作流
1. 为什么需要Word文档自动化 作为一个常年和文档打交道的开发者,我深刻理解手动处理Word文档的痛苦。每次要批量修改格式、插入表格或者调整样式,都得重复点击鼠标,效率低还容易出错。直到发现了Word-MCP-Server这个神器,配合Cu…...
