枚举和List的几个共有方法

2024-04-03 18:08
文章标签 方法 几个 list 枚举 共有

本文主要是介绍枚举和List的几个共有方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.如何判断一个值在枚举的元素中?

有时候我们需要判断一下一个值是否包含在一个枚举类型中,然后根据判断进行下一步操作。那么如何实现枚举类型的包含判断,而且能够像工具类一般的存在。所以我决定用反射来实现枚举类型的包含操作。但是唯一不足的地方是我们的method限定在getValue,也就是我们的枚举类的值必然要有一个value的值以及get、set方法。你还有什么更好的意见吗?有的话请留言,谢谢。

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;/*** @Author: tianjingle* @Date: 2019/8/14 17:26*/
public class EnumUtil {public static boolean isContrain(Class clazz,int type) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException {Object[] objs = clazz.getEnumConstants();Method getValue=clazz.getMethod("getValue");boolean flag=false;for (Object vo:objs) {if (getValue.invoke(vo).equals(type)){flag=true;break;}else {continue;}}return flag;}
}

2.List如何去重?

我们知道HashSet除了在元素的存储上是无序的以外,还是不能够存储重复的元素。

HashSet如何判断元素是否重复呢?是根据元素继承的两个方法来判断,hashCode和equals,当存储元素时,首先判断要存入的元素和已存在的元素的哈希值是否相同,若不相同存入,若相同则利用equals判断两个元素是否相同,若不相同,则存入,若相同则放弃。而hashCode和equlas是在存入元素自动调用的。

所以我们第一想到的是将list转化为hashSet,然后将hashSet转回来。就可以实现List的去重。

    /*** list<string>去重* @param list* @return*/public List removeDuplicate(List list) {HashSet h = new HashSet(list);list.clear();list.addAll(h);return list;}


3.List如何筛选?

查找了很长时间,发现java8的特性是函数式编程,目前还不太懂。但我觉得应该是像建造者模式那种。在java8中提供了流技术,而流技术能够解决这个问题。具体流技术的原理可以看这篇文章:https://www.cnblogs.com/CarpenterLee/p/6637118.html

现在可以尝试写一下使用stream来筛选list。

定义Student

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Student {private String name;private int stuNum;private int age;
}
public class TestStream {/*** @Description 创建四个学生对象并设值,保存在list集合中,模拟数据* @author 刘鹏博* @return List<Student>*/public static List<Student> stuList() {List<Student> stuList = new ArrayList<Student>();Student stu1 = new Student();stu1.setStuNum(20180823);stu1.setName("张三");stu1.setAge(20);stuList.add(stu1);Student stu2 = new Student();stu2.setStuNum(20180824);stu2.setName("李四");stu2.setAge(21);stuList.add(stu2);Student stu3 = new Student();stu3.setStuNum(20180825);stu3.setName("王二");stu3.setAge(21);stuList.add(stu3);Student stu4 = new Student();stu4.setStuNum(20180826);stu4.setName("张五");stu4.setAge(22);stuList.add(stu4);return stuList;}public static void main(String[] args) {System.out.println(LitSourceType.Unknown);List<Student> stuList = stuList();// JDK1.8提供了lambda表达式, 可以从stuList中过滤出符合条件的结果。// 定义结果集List<Student> result = null;result = stuList.stream().filter((Student s) -> s.getAge()==21).collect(Collectors.toList());// 打印原有stuList集合中的数据System.out.println("原有stuList集合中的数据");stuList.forEach((Student s) -> System.out.println(s.getName() + "--->" + s.getAge()));// 打印过滤筛选后的result结果System.out.println("过滤筛选后的result结果");result.forEach((Student s) -> System.out.println(s.getName() + "--->" + s.getAge()));}}

这里我们筛选了21岁的同学。

至于stream的原理,很重要。

这篇关于枚举和List的几个共有方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

每天认识几个maven依赖(ActiveMQ+activemq-jaxb+activesoap+activespace+adarwin)

八、ActiveMQ 1、是什么? ActiveMQ 是一个开源的消息中间件(Message Broker),由 Apache 软件基金会开发和维护。它实现了 Java 消息服务(Java Message Service, JMS)规范,并支持多种消息传递协议,包括 AMQP、MQTT 和 OpenWire 等。 2、有什么用? 可靠性:ActiveMQ 提供了消息持久性和事务支持,确保消

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。 想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。 当时都是在10进制下的。 10进制下的做法是: 1. n阶位数:直接 lg(n!)就是得数的位数。 2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

hdu 2489 (dfs枚举 + prim)

题意: 对于一棵顶点和边都有权值的树,使用下面的等式来计算Ratio 给定一个n 个顶点的完全图及它所有顶点和边的权值,找到一个该图含有m 个顶点的子图,并且让这个子图的Ratio 值在所有m 个顶点的树中最小。 解析: 因为数据量不大,先用dfs枚举搭配出m个子节点,算出点和,然后套个prim算出边和,每次比较大小即可。 dfs没有写好,A的老泪纵横。 错在把index在d

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出 在数字化时代,文本到语音(Text-to-Speech, TTS)技术已成为人机交互的关键桥梁,无论是为视障人士提供辅助阅读,还是为智能助手注入声音的灵魂,TTS 技术都扮演着至关重要的角色。从最初的拼接式方法到参数化技术,再到现今的深度学习解决方案,TTS 技术经历了一段长足的进步。这篇文章将带您穿越时