花几千上万学习Java,真没必要!(三十四)
1、泛型类:
测试代码:
创建一个Box类;
package settest.com;
public class Box<T> { // T stands for "Type" - T是一个占位符,用于表示具体的类型 // 类的内部可以使用T作为类型声明变量 private T t; // 构造方法,用于设置对象的值 public void set(T t) { this.t = t; } // 获取存储的对象 public T get() { return t; }
}
测试代码:
package settest.com;
public class GenericBoxTest { public static void main(String[] args) { // 创建一个可以存储String的Box Box<String> stringBox = new Box<>(); stringBox.set("Hello World"); System.out.println(stringBox.get()); // 创建一个可以存储Integer的Box Box<Integer> integerBox = new Box<>(); integerBox.set(100); System.out.println(integerBox.get()); // 下面的代码会引发编译错误,因为类型不匹配 //stringBox.set(100); // 错误:类型不兼容。 }
}
运行结果如下:
2、泛型方法:
测试代码1:
package settest.com;public class GenericMethodTest {// 泛型方法printArray,可以接受任何类型的数组并打印。public static <E> void printArray(E[] inputArray) {// 显示数组元素for (E element : inputArray) {System.out.printf("%s ", element);}System.out.println();}public static void main(String[] args) {// 创建不同类型数组: Integer, Double 和 CharacterInteger[] intArray = { 1, 2, 3, 4, 5 };Double[] doubleArray = { 1.1, 2.2, 3.3, 4.4 };Character[] charArray = { 'H', 'E', 'L', 'L', 'O' };String[] stringArray = { "Java", "Generics", "Method" };System.out.println("整型数组元素为:");printArray(intArray); // 传递一个整型数组System.out.println("\n双精度型数组元素为:");printArray(doubleArray); // 传递一个双精度型数组System.out.println("\n字符型数组元素为:");printArray(charArray); // 传递一个字符型数组System.out.println("\n字符串数组元素为:");printArray(stringArray); // 传递一个字符串数组}
}
运行结果如下:
测试代码2:
package maptest.com;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List; public class ListUtilsAndMain { // 泛型方法public static <T extends Comparable<? super T>> void sort(List<T> list) { //排序,List是泛型,需要确保列表中的元素类型是可以比较的(即实现Comparable接口)Collections.sort(list); } public static void reverse(List<?> list) { //反转列表中的元素顺序不需要列表元素实现任何接口,它只是简单地交换列表中的元素位置。Collections.reverse(list); } public static void shuffle(List<?> list) { //打乱列表中的元素顺序使用一个随机源重新排列元素Collections.shuffle(list); } public static void main(String[] args) { // ArrayList 确保列表是可修改的 List<Integer> numbers = new ArrayList<>(Arrays.asList(5, 3, 8, 4, 2)); System.out.println("Original: " + numbers); sort(numbers); System.out.println("Sorted: " + numbers); reverse(numbers); System.out.println("Reversed: " + numbers); shuffle(numbers); System.out.println("Shuffled: " + numbers); }
}
运行结果如下;
3、泛型接口:
创建一个 Holder泛型接口:
package settest.com;
//定义泛型接口Holder,它有一个泛型方法get用于获取存储的数据。
public interface Holder<T> { // 获取存储的数据 T get(); }
创建一个SimpleHolder类:
package settest.com;
//创建一个具体的SimpleHolder类,该类可以存储并返回任何类型的数据。
public class SimpleHolder<T> implements Holder<T> {private T data;public SimpleHolder(T data) {this.data = data;}@Overridepublic T get() {return data;}
}
测试代码:
package settest.com;
//在需要封装单个值或对象时非常有用。
public class GenericInterfaceTest { public static void main(String[] args) { // 创建一个持有String的Holder Holder<String> stringHolder = new SimpleHolder<>("Hello, World!"); System.out.println(stringHolder.get()); // 创建一个持有Integer的Holder Holder<Integer> integerHolder = new SimpleHolder<>(42); System.out.println(integerHolder.get()); }
}
运行结果如下:
4、类型通配符;
测试代码:
能力有限,希望各位朋友,各位网友别见笑。
/无界通配符适合只读操作且不关心具体类型,上界通配符适合只读操作且需要子类型关系,下界通配符适合写操作且需要添加特定类型或其子类型的元素。
class Animal {
}class Dog extends Animal {
}class Cat extends Animal {
}public class WildcardExample {public static void main(String[] args) {// 无界通配符List<?> unboundedList = new ArrayList<>();unboundedList = new ArrayList<Animal>();// 无法添加除null之外的任何元素// unboundedList.add(new Animal());unboundedList.add(null);if (!unboundedList.isEmpty()) {// 如果列表不为空,安全地访问第一个元素// 可以读取元素Object element = unboundedList.get(0);System.out.println("第一个元素是: " + element);} else {// 如果列表为空,打印一条消息System.out.println("列表是空的,没有元素可以访问。");}// 上界通配符List<? extends Animal> upperBoundedList = new ArrayList<>();upperBoundedList = new ArrayList<Dog>();// 无法添加任何元素// upperBoundedList.add(new Dog());// 可以读取元素,且元素类型为Animal或其子类if (!upperBoundedList.isEmpty()) {// 如果列表不为空,安全地访问第一个元素Animal animal = upperBoundedList.get(0);System.out.println("第一个元素是: " + animal);} else {// 如果列表为空,打印一条消息System.out.println("列表是空的,没有元素可以访问。");}// 下界通配符List<? super Dog> lowerBoundedList = new ArrayList<>();// 可以添加Dog及其子类元素lowerBoundedList.add(new Dog());// 可以读取元素,但需要进行类型转换Object obj = lowerBoundedList.get(0);if (obj instanceof Dog) {Dog dog = (Dog) obj;System.out.println("Dog: " + dog);}}
}
运行结果如下;
5、可变参数:
1. Arrays.asList(T... a)
方法签名:public static <T> List<T> asList(T... a)
功能:该方法将传入的数组转换成一个固定大小的列表。这个列表是由原始数组支持的,因此对列表的非结构性修改(即修改元素的值,如果元素是可变的)会反映到原始数组中,反之亦然。但是,这个列表的大小是固定的,尝试进行结构性修改(如添加、删除元素)会抛出ConcurrentModificationException异常(如果迭代器正在使用中)或UnsupportedOperationException(如果直接调用add、remove等方法)。
限制:返回的列表大小固定,不支持增删操作,但支持修改元素(如果元素本身是可变的)。
2. List.of(E... elements)
方法签名:public static <E> List<E> of(E... elements)(这是Java 9及以后版本引入的)
功能:该方法创建了一个包含任意数量元素的不可变列表。这个列表的大小在创建时就确定了,之后不能修改(即不支持增删改操作)。
限制:返回的列表不可变,不支持增删改操作。
3. Set.of(E... elements)
方法签名:public static <E> Set<E> of(E... elements)(这是Java 9及以后版本引入的)
功能:该方法创建了一个包含任意数量元素的不可变集合。这个集合不允许重复元素,如果尝试添加重复元素,将抛出IllegalArgumentException。集合的大小在创建时就确定了,之后不能修改(即不支持增删改操作)。
限制:返回的集合不可变,不支持增删改操作,且元素唯一,不允许重复。
总结
Arrays.asList返回的列表大小固定,不支持增删操作,但支持修改元素(如果元素本身是可变的)。
List.of和Set.of返回的都是不可变集合,不支持增删改操作。List.of可以包含重复元素,而Set.of则不允许重复元素。
测试代码1:
package settest.com;public class VarargsExample {// 第一个参数是String类型,第二个可变参数是int类型。// 实际上,不会在同一个方法中使用多个可变参数,而是使用单个可变参数或者不使用可变参数。public void printMessages(String prefix, int... numbers) {for (int number : numbers) {System.out.println(prefix + ": " + number);}}public static void main(String[] args) {VarargsExample example = new VarargsExample();example.printMessages("Number", 1, 2, 3, 4, 5);// 如果将可变参数放在非可变参数之前,编译器会报错。// public void wrongMethod(int... numbers, String prefix) {...}}
}
运行结果如下:
测试代码2:
package settest.com;
import java.util.*;public class VariableParameters {public static void main(String[] args) {// 使用 Arrays.asList 方法创建固定大小的不可变 ListList<String> fixedList = Arrays.asList("apple", "banana", "cherry");System.out.println("Fixed List: " + fixedList);// 使用 List.of 方法创建不可变 ListList<String> immutableList = List.of("apple", "banana", "cherry");System.out.println("Immutable List: " + immutableList);// 尝试修改不可变 List,会抛出 UnsupportedOperationException 异常// immutableList.add("date");// 使用 Set.of 方法创建不可变 SetSet<String> immutableSet = Set.of("apple", "banana", "cherry");System.out.println("Immutable Set: " + immutableSet);// 尝试添加重复元素到不可变 Set,会抛出 IllegalArgumentException 异常// Set<String> immutableSetWithDuplicate = Set.of("apple", "banana", "apple");// 尝试修改不可变 Set,会抛出 UnsupportedOperationException 异常// immutableSet.add("date");}
}
运行结果如下:
相关文章:

花几千上万学习Java,真没必要!(三十四)
1、泛型类: 测试代码: 创建一个Box类; package settest.com; public class Box<T> { // T stands for "Type" - T是一个占位符,用于表示具体的类型 // 类的内部可以使用T作为类型声明变量 private T t; // 构造方法&am…...

【代码】Python3|Scrapy框架初探(汽车之家大连市二手车车辆数据爬取、清洗与可视化)
本篇主要是整个项目的介绍,没提到太多琐碎的技术细节,以后有空的话会整理一下 Scrapy 和原生爬虫的差异,还有它坑人的一些地方,单发出来。 开源地址:https://github.com/shandianchengzi/car_home_spider 使用说明&a…...
C#中的new以及类
new关键字的用法 实例化对象:使用 new 关键字可以创建一个类的实例。例如: MyClass obj new MyClass(); 指定构造函数:如果类有多个构造函数,可以使用 new 关键字指定使用哪一个构造函数来创建对象。例如: MyC…...

Hbase简介和快速入门
一 Hbase简介 1 HBase定义 Apache HBase™ 是以hdfs为数据存储的,一种分布式、可扩展的NoSQL数据库。 2 HBase数据模型 HBase的设计理念依据Google的BigTable论文,论文中对于数据模型的首句介绍。Bigtable 是一个稀疏的、分布式的、持久的多维排序map…...

【AI落地应用实战】Amazon Bedrock +Amazon Step Functions实现链式提示(Prompt Chaining)
一、链式提示 Prompt Chaining架构 Prompt Chaining 是一种在生成式人工智能(如大型语言模型)中广泛使用的技术,它允许用户通过一系列精心设计的提示(Prompts)来引导模型生成更加精确、丰富且符合特定需求的内容。 P…...
vue Ref 和 Reactive 原理解析
文章目录 RefReactive Ref ref 的语义是指向一个值的引用,主要用于处理基本数据类型和单一值对象,即对值的引用进行包装和管理,而不是对对象的操作进行拦截,对于基础类型通过 getter 和 setter 实现拦截使用 Proxy 拦截对象的所有…...

【人工智能】Transformers之Pipeline(六):图像分类(image-classification)
目录 一、引言 二、图像分类(image-classification) 2.1 概述 2.2 技术原理 2.3 应用场景 2.4 pipeline参数 2.4.1 pipeline对象实例化参数 2.4.2 pipeline对象使用参数 2.4 pipeline实战 2.5 模型排名 三、总结 一、引言 pipeline&#x…...
编程语言漫谈之「初始化与赋值」——以C++和汇编语言为示例
编程语言漫谈之「初始化与赋值」——以C和汇编语言为示例 1. 赋值时汇编做了什么2. 在变量定义时做初始化, 与在使用时才进行初始化, 有区别吗? 1. 赋值时汇编做了什么 当我们在C中写下如下代码: int main() {int a 10;return 0; }这是一个简单的整数类型变量a的初始化赋值…...
windows使用ssh-agent管理私钥
主要有以下几个方面: 开启openssh 的 ssh-agent 服务 打开powershell 输入 Get-Service -Name ssh-agent 查看服务是否起来Start-Service ssh-agent 启动服务Stop-Service ssh-agent 关闭服务将私钥添加到ssh-agent 添加私钥 ssh-add ~/.ssh/id_rsa查询添加哪些私钥 ssh-add -…...
PostgreSQL 之 to_timestamp函数
to_timestamp 是 PostgreSQL 中的一个函数,用于将字符串或数字转换为时间戳。以下是关于 to_timestamp 的详细介绍: 引入版本 to_timestamp 函数在 PostgreSQL 7.3 版本中引入。 语法 to_timestamp 有两种主要的用法: 1.将字符串转换为时间戳 to_timestamp(text, text)第…...

USB3.0的等长要求到底是多少?
USB2.0与USB3.0接口的PCB布局布线要求PCB资源PCB联盟网 - Powered by Discuz! (pcbbar.com) 90欧姆阻抗,走差分线: 重点来了:...

力扣高频SQL 50题(基础版)第二十五题
文章目录 力扣高频SQL 50题(基础版)第二十五题619.只出现一次的最大数字题目说明实现过程准备数据实现方式结果截图 力扣高频SQL 50题(基础版)第二十五题 619.只出现一次的最大数字 题目说明 MyNumbers 表: ------…...

【C++题解】1581. 马里奥的银币1
问题:1581. 马里奥的银币1 类型:数组找数 题目描述: 马里奥有很多银币,有一天他得到了一张魔法卡,只要使用这张魔法卡,就可以使得他的银币里面的最大的银币金额变得更大。如果他最大的银币是偶数的金额&a…...
system和popen函数的异同点
system和popen函数的异同点 文章目录 system和popen函数的异同点1.什么是shell命令2.system 函数3.popen 函数4.总结 1.什么是shell命令 Shell 命令是在类 UNIX 操作系统(包括 UNIX、Linux 和 macOS 等)的 Shell 中执行的指令。Shell 是操作系统的命令行…...

Python小工具之httpstat网络分析
一、简介 Python httpstat是一个基于Python的命令行工具,用于测量HTTP请求的性能和状态信息。它能够向目标服务器发送HTTP请求,并显示详细的统计信息,包括DNS解析时间、建立连接时间、TLS/SSL握手时间、首字节时间、总时间等。这些信息对于排…...

挑战房市预测领头羊:KNN vs. 决策树 vs. 线性回归
挑战房市预测领头羊(KNN,决策树,线性回归) 1. 介绍1.1 K最近邻(KNN):与邻居的友谊1.1.1 KNN的基础1.1.2 KNN的运作机制1.1.3 KNN的优缺点 1.2 决策树:解码房价的逻辑树1.2.1 决策树的…...
Docker 基础知识
Docker 基础知识 什么是 Docker? Docker 是一个开源平台,用于开发、发布和运行应用程序。Docker 通过将应用程序及其依赖项打包到一个称为容器的可移植单元中来工作。 Docker 的核心组件是什么? Docker Engine:核心组件࿰…...

视频主题Qinmei 3.0视频站源码_WordPress影视视频主题/附详细安装教程
Qinmei 3.0主题主要是将 wordpress 改造成纯 api 的站点,以便实现前后端分离的技术栈,目前的进度已经大致完成,唯一的问题就是需要安装 JWT token 插件。 功能介绍: 支持豆瓣以及 bangumi 的一键获取信息, 豆瓣 api 目前使用的是…...

数字看板:跨行业需求下的创新与升级
在当今这个数据驱动的时代,数字看板作为信息展示与决策支持的重要工具,正逐步渗透到各行各业之中。从智慧城市到智能制造,从金融分析到医疗健康,数字看板以其直观、动态、高效的特点,成为了连接数据与决策者的桥梁。本…...

02、爬虫数据解析-Re解析
数据解析的目的是不拿到页面的全部内容,只拿到部分我们想要的内容内容。 Re解析就是正则解析,效率高准确性高。学习本节内容前需要学会基础的正则表达式。 一、正则匹配规则 1、常用元字符 . 匹配除换行符以外的字符 \w 匹配字母或数字或下划…...

XCTF-web-easyupload
试了试php,php7,pht,phtml等,都没有用 尝试.user.ini 抓包修改将.user.ini修改为jpg图片 在上传一个123.jpg 用蚁剑连接,得到flag...
django filter 统计数量 按属性去重
在Django中,如果你想要根据某个属性对查询集进行去重并统计数量,你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求: 方法1:使用annotate()和Count 假设你有一个模型Item,并且你想…...

全球首个30米分辨率湿地数据集(2000—2022)
数据简介 今天我们分享的数据是全球30米分辨率湿地数据集,包含8种湿地亚类,该数据以0.5X0.5的瓦片存储,我们整理了所有属于中国的瓦片名称与其对应省份,方便大家研究使用。 该数据集作为全球首个30米分辨率、覆盖2000–2022年时间…...
数据链路层的主要功能是什么
数据链路层(OSI模型第2层)的核心功能是在相邻网络节点(如交换机、主机)间提供可靠的数据帧传输服务,主要职责包括: 🔑 核心功能详解: 帧封装与解封装 封装: 将网络层下发…...

Cloudflare 从 Nginx 到 Pingora:性能、效率与安全的全面升级
在互联网的快速发展中,高性能、高效率和高安全性的网络服务成为了各大互联网基础设施提供商的核心追求。Cloudflare 作为全球领先的互联网安全和基础设施公司,近期做出了一个重大技术决策:弃用长期使用的 Nginx,转而采用其内部开发…...
鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个生活电费的缴纳和查询小程序
一、项目初始化与配置 1. 创建项目 ohpm init harmony/utility-payment-app 2. 配置权限 // module.json5 {"requestPermissions": [{"name": "ohos.permission.INTERNET"},{"name": "ohos.permission.GET_NETWORK_INFO"…...

深入解析C++中的extern关键字:跨文件共享变量与函数的终极指南
🚀 C extern 关键字深度解析:跨文件编程的终极指南 📅 更新时间:2025年6月5日 🏷️ 标签:C | extern关键字 | 多文件编程 | 链接与声明 | 现代C 文章目录 前言🔥一、extern 是什么?&…...

python执行测试用例,allure报乱码且未成功生成报告
allure执行测试用例时显示乱码:‘allure’ �����ڲ����ⲿ���Ҳ���ǿ�&am…...
laravel8+vue3.0+element-plus搭建方法
创建 laravel8 项目 composer create-project --prefer-dist laravel/laravel laravel8 8.* 安装 laravel/ui composer require laravel/ui 修改 package.json 文件 "devDependencies": {"vue/compiler-sfc": "^3.0.7","axios": …...
服务器--宝塔命令
一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行! sudo su - 1. CentOS 系统: yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...