最近,我打算对我们项目的代码进行清理,准备把一些没有被使用到的公用方法清理掉,但是我在网络找了一遍,像PMD,Findbugs等静态工具,都只能找到没有被使用的私有方法。...*/ public boolean isCallAuth(String str) { return isInculeList(str, callAuths); } /** * 判断一个字符串是否在一个数据列表中... } /** * 获取没有被使用的代码 * @param path * @param className * @param codeNames * @param type ... classObject = classList.get(i); //得到一个类中没有使用的属性列表 unUsedAttrList = getUnUsedCode(path,...unUsedAttrList.isEmpty())) { //增加数据 result.addAll(unUsedAttrList); } //得到一个类中没有使用的属性列表
LocalDateTime在java中的使用 说明 1、LocalDateTime是一个日期-时间目标。您还可以将其视为LocalDate和LocalTime的组合。在操作上,也大致相同。...Instance 可以转换成旧版本的java.util.Date对象。...Date.from(instant); System.out.println(legacyDate); // Wed Dec 31 23:59:59 CET 2014 以上就是LocalDateTime在java...中的使用,希望对大家有所帮助。
最近在把一个数组或字符串转化成对象时,使用了Google的Gson感觉不错,下面我以代码的形式详细举例来介绍 上面的注释部分为输出结果,使用了maven ,这里是Gson的maven依赖 <dependency...; import java.util.ArrayList; import java.util.Date; import java.util.HashMap; import java.util.List;...; public class AllInAllGSON { Gson gson = new Gson();//生成一个json对象 @Test /** *...System.out.println(x1+ " "+ x2+" "+x3); int [] n3 = gson.fromJson(x1, int[].class);//把一个...Bob */ public void stuClass(){ Student b = new Student("Bob", "Baa St", null);//对一个类的属性进行转成
UUID的复杂性决定了“一般人“不能直接从一个UUID知道哪个对象和它关联。 在特定的范围内重复的可能性极小UUID的生成规范定义的算法主要目的就是要保证其唯一性。...如果应用只是在局域网中使用,也可以使用退化的算法,以IP地址来代替MAC地址--Java的UUID往往是这样实现的(当然也考虑了获取MAC的难度)。...JAVA中UUID的使用 我们来看看在JAVA中UUID的使用方式: 查看jdk提供的uuid的api发现。...我们通过一个非常简单的例子来展示UUID的使用: package byron4j.dlzd; import java.util.UUID; public class UuidDemo { public...4、3; 因为我们更趋向于使用版本3、5的算法实现, 所以在实际生产中,推荐使用 nameUUIDFromBytes方法将自身的唯一id转换为UUID形式。
⌨ Java常用类Random解析,伪随机数的生成 摘要 作为一名博主,我将在本文中深入探讨Java中的常用类Random,以及如何使用它生成伪随机数。...我们将研究Random类的方法、随机原理、应用场景以及一些常见面试题,帮助您更好地理解和使用这个类。让我们一起探索伪随机数生成的奥秘! 引言 在计算机编程中,随机数生成是一个常见而重要的任务。...这个算法是一个确定性的过程,意味着给定相同的输入,它将产生相同的输出,因此种子的选择变得非常重要。 伪随机数生成器算法:Random类使用一个伪随机数生成器算法来生成随机数。...种子的重要性:种子是决定随机数生成的起点。不同的种子将导致不同的随机数序列。这意味着,如果您希望在不同的时间点或不同的应用中获得相同的随机数序列,只需使用相同的种子。...您可以通过在 Random 对象的构造函数中传递相同的种子来设置种子,以获得可重复的随机数序列。
Date 在java中的使用 博主 默语带您 Go to New World....请注意,尽管这些方法可以在 Java 8 中使用,但新的日期时间 API(java.time 包)提供了更多功能和更好的可读性,因此在新的代码中更推荐使用新的 API。 ️...在JDK 17中,Date类保留了其基本方法,但已被标记为过时,建议使用新的日期和时间类。 Java 17 版本中并没有对 java.util.Date 类进行扩展或优化。...但请注意,这不是 Java 17 的新功能,而只是一个示例。如果可能的话,仍然建议使用 java.time 包中的类进行日期和时间操作。...在 Java 中,您可以使用 java.sql.Date 或 java.time.LocalDate 类来表示只包含日期的日期对象。
本片将介绍 Redis 在 Java 中的基本使用 1、使用jedis操作redis 1.1、Jedis简介 Jedis 是 Java 语言开发的 Redis 客户端工具包,用于 Java 语言与 Redis...在 getUserById 方法中,我们首先构造了一个缓存的 key,然后使用 redisUtils.getValue 方法从 Redis 中获取缓存数据。...如果缓存中没有数据,我们调用 userService.getUserById 方法从数据库中获取数据,并使用 redisUtils.cacheValue 方法将数据存入Redis缓存中。...最后,返回获取到的数据。 通过这个示例,我们可以看到,在S pringBoot 项目中使用 Redis 作为缓存的流程。我们首先需要添加 Redis 依赖,然后在配置文件中配置 Redis 连接信息。...接着,我们创建了一个 RedisUtil s工具类来管理 RedisTemplate 的创建和使用。最后,我们在控制器中使用 RedisUtils 来对 Redis 进行缓存操作。
java中reduce在流的使用 1、说明 从一个流中生成一个值,有三个重载方法。...通过参与的Function,我们可以将list归类为一个值。其返回类型为Optional类型。...#" + s2); reduced.ifPresent(System.out::println); // "aaa1#aaa2#bbb1#bbb2#bbb3#ccc#ddd1#ddd2" 以上就是java...中reduce在流的使用,希望对大家有所帮助。
[TOC] 0x00 快速入门 在前面的学习中我们知道了XML的基础用法,和它的解析器方式包括DOM和SAX方式,在Java中处理操作XML文件常用的解决方案是Jaxp、Jdom,dom4j等等,其中后者最为常用且本文学习也是采用...---- 0x01 基本用法 Dom4j的使用流程: 1.创建SAXReader对象 2.指定读取解析的xml 3.获取根元素document.getRootElement(); 4.根据元素获取子元素或者下面的子孙元素...描述:在dom4j里面支持xpath的写法,xpath其实是xml的路径语言,支持我们再解析xml的时候,能够快速的定位到具体的某一个元素中; 实验结构: WeiyiGeek....使用流程: 1.添加jaxen-1.1-beta-6.jar依赖流程; 2.在查找指定节点时候根据XPath语法规则来查询; 3.利用Xpath获取节点采用rootElement.selectSingleNode...Element xpathElement = (Element) rootElement.selectSingleNode("//name"); System.out.println("获取一个子孙元素的值
[TOC] 0x00 快速入门 在前面的学习中我们知道了XML的基础用法,和它的解析器方式包括DOM和SAX方式,在Java中处理操作XML文件常用的解决方案是Jaxp、Jdom,dom4j等等,其中后者最为常用且本文学习也是采用...WeiyiGeek.Dom4j 0x01 基本用法 Dom4j的使用流程: 1.创建SAXReader对象 2.指定读取解析的xml 3.获取根元素document.getRootElement();...描述:在dom4j里面支持xpath的写法,xpath其实是xml的路径语言,支持我们再解析xml的时候,能够快速的定位到具体的某一个元素中; 实验结构: ?...使用流程: 1.添加jaxen-1.1-beta-6.jar依赖流程; 2.在查找指定节点时候根据XPath语法规则来查询; 3.利用Xpath获取节点采用rootElement.selectSingleNode...Element xpathElement = (Element) rootElement.selectSingleNode("//name"); System.out.println("获取一个子孙元素的值
properties需要从官网/github下载,data文件夹下载 项目配置 修改hanlp.properties: 1 #/Test/src/hanlp.properties: 2 #本配置文件中的路径的根目录...配置文件的作用是告诉HanLP数据包即data文件夹的位置,root的值为data文件夹的父目录,可以使用绝对路径或相对路径。...而,对于一个(或一些)给定的数值,算法的结果并不是唯一的或确定的。...\n" 72 + "三,无限的算法,是那些由于没有定义终止定义条件,或定义的条件无法由输入的数据满足而不终止运行的算法。通常,无限算法的产生是由于未能确定的定义终止条件。"...如果一个算法有缺陷,或不适合于某个问题,执行这个算法将不会解决这个问题。不同的算法可能用不同的时间、空间或效率来完成同样的任务。一个算法的优劣可以用空间复杂度与时间复杂度来衡量。
当你希望在 Map 中不使用 String 为 Key,那么你需要使用 MessagePackKeySerializer 来为 key 进行序列化。...本测试方法,可以在 https://github.com/cwiki-us-demo/serialize-deserialize-demo-java/blob/master/src/test/java/...com/insight/demo/serialize/MessagePackSerializer.java 中找到。...messageData.setName("CWIKI.US - B"); map.put(uuid_b, messageData); try { // Serialize a Java
在现实生活中,很多场景都需要ID生成器,比如说电商平台的订单号生成、银行的叫号系统等。...对于自增序列的ID生成器,在多并发环境下,为保证严格的自增,常常可以通过锁来保证。 ?...设想一下,如果我们想在应用层面自己实现一个自增序列的ID生成器(其实本质上我们需要实现的是一个getNextValue方法),怎么做?...在分布式系统中,如何实现ID生成器,有很多办法,有兴趣的童鞋可以自行网上搜索。下面主要分析JPA的ID生成器是如何依赖于数据库的锁实现的。 ?...那么在分布式环境下,ID生成器是不是也可以采用CAS呢?这篇文章(浅谈CAS在分布式ID生成方案上的应用 | 架构师之路)就简单介绍了如何采用CAS实现分布式ID生成器。
目录 1 需求 2 代码实现 1 需求 现在有两个list集合,A 集合 B集合; 两个集合里面都存储user对象, 现在要将B集合里面,不在A集合的数据过滤出来之后,得到; 就是取差集; 2 代码实现...System.out.println(item.getName()); } @Data public class UserInfo { private int id...= o.getClass()) return false; UserInfo userInfo = (UserInfo) o; return id == userInfo.id...; } @Override public int hashCode() { return Objects.hash(id, name); } }
在某些数据变化时,其他的类做出一些响应。处理数据(或者分发事件)的类主动投送消息,感兴趣的类主动“订阅”消息。 监听者模式在Android中有大量的运用,相信大家都不会感到陌生。...在Android开发中,Button控件的点击事件就是监听者模式最常见的例子。 当Button被点击,执行了 OnClickListener.onClick。...Activity中给这个Button设置了自己实现的OnClickListener,并复写了onClick方法,就能执行自定义操作了。 Java代码实例 下面来用Java来实现监听者模式。...很多场景中都使用了监听者模式。开发者也可能在不知不觉中就运用了这个模式。 Android中使用监听器 最常见的例子是给Button设置点击事件监听器。 类似上个例子,设计一个接口当做监听器。...Android中回调时可以利用handler,控制调用的线程。
一、引子 今天下午遇到一个NPE,如下图所示 ?...image.png 之前没仔细查过Stream的源码,也没有深究背后的原因,今天跟了下源码,最后跟到ReferencePipeline#193行,应该是调用apply的时候,入参u为null,从而触发了空指针异常...Collectors.toList()); } public static Long get(long userId) { return userId; } 二、最佳实践 在Streams...开始和结束之前,都需要避免处理null值,使用filter可以过滤掉; 不要滥用Streams,因为我发现Stream有时候会让代码变得更难以阅读; 针对Collections的迭代处理,可以多用Stream...处理; 要谨慎使用Parallel Streams,性能不一定比普通的loop要好; 最后:对外暴露API的入参检查需要更全面; 参考资料 Java SE 8最佳实践 流处理线:ReferencePipeline
几乎是边查文档编写,记录写编写过程: 查找目录下所有java文件 查找Java文件中含有Toast相关的行 在对应行中找出对应的id 使用id在String中查找对应的toast提示信息。...查找目录下所有java文件 这个我是直接copy网上递归遍历的,省略。...查找Java文件中的Toast 需要找出Toast的特征,项目中有两个Toast类 BannerTips和ToastUtils 两个类。 1.先代码过滤对应的行。...找到BannerTips、ToastUtils调用的地方 2.找出提示的地方 3.观察其实项目中的id的前面均含有R.string. 可以以此作为区分。...在对应行中找出对应的id 使用id在String中查找对应的toast提示信息。 最后去重。 最后一个比较简单,可以自己写,也可以解析下xml写。
分布式 ID 生成器 一个唯一 ID 在一个分布式系统中是非常重要的一个业务属性,其中包括一些如订单 ID,消息 ID ,会话 ID,他们都有一些共有的特性: 全局唯一。 趋势递增。...通常有以下几种方案: 基于数据库 可以利用 MySQL 中的自增属性 auto_increment 来生成全局唯一 ID,也能保证趋势递增。...本地 UUID 生成 还可以采用 UUID 的方式生成唯一 ID,由于是在本地生成没有了网络之类的消耗,所有效率非常高。 但也有以下几个问题: 生成的 ID 是无序性的,不能做到趋势递增。...采用本地时间 这种做法非常简单,可以利用本地的毫秒数加上一些业务 ID 来生成唯一ID,这样可以做到趋势递增,并且是在本地生成效率也很高。...但有一个致命的缺点:当并发量足够高的时候唯一性就不能保证了。 Twitter 雪花算法 可以基于 Twitter 的 Snowflake 算法来实现。
import java.util.Scanner; Scanner scanner=new Scanner(); char sex=scanner.next().charAt(0);
领取专属 10元无门槛券
手把手带您无忧上云