Java編程泛型限定代碼分享
泛型 一般 出現(xiàn)在集合中,迭代器中 也會出現(xiàn)!
泛型 是為了 提高代碼的 安全性。 泛型 確保數(shù)據(jù)類型的唯一性。
在我們常用的容器中, 越是單一越好處理??!
泛型的限定:
? 是通配符 指代 任意類型
泛型的限定上限:
<? extends E> 接受 E 或者 E 的子類型。
泛型的限定下限:
<? super E> 接收 E 或者 E 的父類。
泛型的限定上限 (定義父類 填裝子類 類型?。?/p>
下面我們看看具體代碼示例
package newFeatures8; import java.util.*; /* ? 通配符。也可以理解為占位符。 泛型的限定; ? extends E: 可以接收E類型或者E的子類型。上限。 ? super E: 可以接收E類型或者E的父類型。下限 */ class GenericDemo6 { public static void main(String[] args) { /* * ArrayList<String> al = new ArrayList<String>(); * * al.add("abc1"); al.add("abc2"); al.add("abc3"); * * ArrayList<Integer> al1 = new ArrayList<Integer>(); al1.add(4); * al1.add(7); al1.add(1); * * printColl(al); printColl(al1); */ //ArrayList<Person> al = new ArrayList<Student>();error //為了解決等號兩邊泛型不一致的情況,jdk1.7以后可以這么寫 ArrayList<Person> al = new ArrayList<>();//右邊的泛型自動反射進(jìn)來 al.add(new Person("abc1")); al.add(new Person("abc2")); al.add(new Person("abc3")); // printColl(al); ArrayList<Student> al1 = new ArrayList<Student>(); al1.add(new Student("abc--1")); al1.add(new Student("abc--2")); al1.add(new Student("abc--3")); printColl(al1); } public static void printColl(Collection<? extends Person> al) { Iterator<? extends Person> it = al.iterator(); while (it.hasNext()) { System.out.println(it.next().getName()); } } /*public static void printColl(ArrayList<?> al) { Iterator<?> it = al.iterator(); while (it.hasNext()) { System.out.println(it.next().toString()); } }*/ } class Person { private String name; Person(String name) { this.name = name; } public String getName() { return name; } } class Student extends Person { Student(String name) { super(name); } } /* class Student implements Comparable<Person> { public int compareTo(Person s){ this.getName() } } */ /* class Comp implements Comparator<Person>{ //<? super E> public int compare(Person s1,Person s2) { //Person s1 = new Student("abc1"); return s1.getName().compareTo(s2.getName()); } } TreeSet<Student> ts = new TreeSet<Student>(new Comp());//TreeSet(Comparator<? super E> comparator) ts.add(new Student("abc1")); ts.add(new Student("abc2")); ts.add(new Student("abc3")); */
總結(jié)
以上就是本文關(guān)于Java編程泛型限定代碼分享的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以參閱:Java編程基礎(chǔ)測試題分享、Java編程redisson實(shí)現(xiàn)分布式鎖代碼示例、Java線程安全與非線程安全解析等,如有不足之處,歡迎留言指出,小編會及時回復(fù)大家并進(jìn)行修改,希望朋友們對本站多多支持!
相關(guān)文章
Java實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)IO版本
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)IO版本,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04Java實(shí)現(xiàn)最小生成樹MST的兩種解法
最小生成樹(MST)指在連通圖的所有生成樹中,所有邊的權(quán)值和最小的生成樹。本文介紹了求最小生成樹的兩種方法:Prim算法和Kruskal算法,需要的可以參考一下2022-05-05Java利用Dijkstra算法求解拓?fù)潢P(guān)系最短路徑
迪杰斯特拉算法(Dijkstra)是由荷蘭計(jì)算機(jī)科學(xué)迪家迪杰斯特拉于1959年提出的,因此又叫狄克斯特拉算法。本文將利用迪克斯特拉(Dijkstra)算法求拓?fù)潢P(guān)系最短路徑,感興趣的可以了解一下2022-07-07詳解java8在Collection中新增加的方法removeIf
這篇文章主要介紹了詳解java8在Collection中新增加的方法removeIf的相關(guān)資料,需要的朋友可以參考下2018-01-01HttpClient的RedirectStrategy重定向處理核心機(jī)制
這篇文章主要為大家介紹了HttpClient的RedirectStrategy重定向處理核心機(jī)制源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10springboot整合minio實(shí)現(xiàn)文件上傳與下載且支持鏈接永久訪問
本文主要介紹了springboot整合minio實(shí)現(xiàn)文件上傳與下載且支持鏈接永久訪問,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01