集合、排序和实用方法中的部分泛型
收藏
从现在开始,努力学习吧!本文《集合、排序和实用方法中的部分泛型》主要讲解了等等相关知识点,我会在米云中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!

在这篇后续文章中,我们将完全关注集合中的泛型、java 集合中类型安全的概念,以及泛型如何使您的代码更加灵活和健壮。此外,我们将探索排序如何与通用集合一起使用以及一些派上用场的高级实用方法。
—
目录
- 泛型简介
- 列表中的泛型
- 集合中的泛型
- 地图中的泛型
- 使用泛型排序
- 高级实用方法
- 常见的泛型错误
- 挑战
- 结论
—
泛型简介
java 中的
泛型 允许您编写适用于任何数据类型的类、接口或方法。通过将泛型与集合结合使用,可以确保编译时的类型安全。这意味着您可以避免潜在的 classcastexception 错误并消除显式转换的需要。
例如:
list<string> strings = new arraylist<>();
strings.add("hello");
// adding a non-string value will now cause a compile-time error.
泛型确保只有指定的数据类型可以存储在集合中,防止运行时问题并使代码更具可读性和可维护性。
—
列表中的泛型
列表中的泛型确保您只能存储指定类型的对象。例如,list<string> 只允许 string 对象,而 list<integer> 只允许 integer 对象。
代码示例
import java.util.arraylist;
import java.util.list;
public class genericlistexample {
public static void main(string[] args) {
list<string> names = new arraylist<>();
names.add("alice");
names.add("bob");
// the following line would cause a compile-time error:
// names.add(123); // error: cannot add integer to list<string>
for (string name : names) {
system.out.println(name);
}
}
}
好处
- 类型安全:编译器将强制只有声明类型的对象才能添加到列表中。
- 无显式转换:从列表中检索元素时无需进行转换。
—
集合中的泛型
具有泛型的集合的工作方式与列表类似,确保所有元素都属于特定类型。
代码示例
import java.util.hashset;
import java.util.set;
public class genericsetexample {
public static void main(string[] args) {
set<integer> numbers = new hashset<>();
numbers.add(10);
numbers.add(20);
numbers.add(30);
// compile-time error if a non-integer is added:
// numbers.add("forty"); // error
for (integer num : numbers) {
system.out.println(num);
}
}
}
好处
- 您以类型安全的方式维护元素的唯一性。
- 确保不添加任何意外的类型。
—
地图中的泛型
映射是键值对,支持键和值的泛型。例如,map<string、integer> 将强制键为 string,值为 integer。
代码示例
import java.util.hashmap;
import java.util.map;
public class genericmapexample {
public static void main(string[] args) {
map<string, integer> phonebook = new hashmap<>();
phonebook.put("alice", 12345);
phonebook.put("bob", 67890);
// the following would cause a compile-time error:
// phonebook.put(123, "charlie"); // error
for (map.entry<string, integer> entry : phonebook.entryset()) {
system.out.println(entry.getkey() + ": " + entry.getvalue());
}
}
}
好处
- 您可以确保 map 中的键和值的类型安全。
- 防止混合类型造成潜在的运行时错误。
—
使用泛型排序
对通用集合进行排序非常简单,可以使用 collections.sort() 进行列表排序,使用 comparable 或 comparator 进行自定义排序。
代码示例
import java.util.arraylist;
import java.util.collections;
import java.util.list;
public class genericsortingexample {
public static void main(string[] args) {
list<integer> numbers = new arraylist<>();
numbers.add(5);
numbers.add(3);
numbers.add(8);
numbers.add(1);
collections.sort(numbers); // sorts in natural order
system.out.println("sorted numbers: " + numbers);
}
}
对于自定义排序,您可以实现 comparator 接口。
—
高级实用方法
集合实用程序类还支持二分搜索、随机播放、反向和频率计数等操作。这些操作可以应用于通用集合以进行更强大的数据操作。
代码示例
import java.util.arraylist;
import java.util.collections;
import java.util.list;
public class utilitymethodsexample {
public static void main(string[] args) {
list<string> items = new arraylist<>();
items.add("apple");
items.add("banana");
items.add("cherry");
// shuffle the list
collections.shuffle(items);
system.out.println("shuffled list: " + items);
// reverse the list
collections.reverse(items);
system.out.println("reversed list: " + items);
// frequency of an item
int freq = collections.frequency(items, "apple");
system.out.println("frequency of apple: " + freq);
}
}
—
常见的泛型错误
- 使用原始类型:使用集合时始终指定类型参数,以避免潜在的运行时问题。
List list = new ArrayList(); // Raw type
list.add("String");
list.add(123); // No compile-time error, but may cause runtime issues
- 错误地使用通配符:将集合传递给方法时,使用通配符如list<?> 或list<?扩展 number> 可能会引起混乱。了解什么时候使用?以及 extends 或 super 关键字。
—
挑战
挑战 1:通用堆栈
使用泛型实现一个简单的堆栈类。堆栈应该支持推送元素、弹出元素以及检查是否为空。
挑战 2:对自定义对象进行排序
创建自定义对象列表,例如人员,并根据年龄或姓名等自定义字段对其进行排序。
—
结论
在这篇文章中,我们探讨了如何使用集合中的泛型来实现类型安全、灵活性和易用性。我们还讨论了排序和高级实用方法,使集合的处理更加高效。通过掌握泛型,您可以编写更健壮、无错误且高度可重用的代码。
—
理论要掌握,实操不能落!以上关于《集合、排序和实用方法中的部分泛型》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注米云公众号吧!
版本声明 本文转载于:dev.to 如有侵犯,请联系删除
