이 기사는 주로 Java 프로그래밍의 일반적인 제한 사항에 대한 내용을 소개합니다. 필요한 친구는 이에 대해 배울 수 있습니다.
제네릭은 일반적으로 컬렉션과 반복자에 나타납니다!
Generics는 코드 보안을 향상시키기 위한 것입니다. 제네릭은 데이터 유형의 고유성을 보장합니다.
우리가 흔히 사용하는 용기는 단순할수록 다루기도 더 쉽습니다!
일반 제한사항:
? 모든 유형을 참조하는 와일드카드 문자입니다.
제네릭의 제한된 상한:
E> E 또는 E의 하위 유형을 허용합니다.
제네릭의 하한:
super E>는 E 또는 E의 상위 클래스를 받습니다.
제네릭의 상한 제한(상위 클래스 정의 및 하위 클래스 유형 입력!)
특정 코드 예제를 살펴보겠습니다.
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<>();//右边的泛型自动反射进来 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")); */
요약
위 내용은 Java의 일반 한정을 위한 코드 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!