<泛型>的认识
来源:互联网 发布:mac vpn推荐 编辑:程序博客网 时间:2024/04/29 19:38
main 方法中:
Arraylist<Person> l=new Arraylist<Person>(); // 确定类型 集合只能存放Person对象
al.add(new Person("zhangsan",20)); //不会报错
//al.add("aaa"); //报错
//al.add(new Dog()) //报错
//加了泛型 迭代器不需要强转了
Iterator<Person>iterator=al.iterator();
while(iterator.hasNext()){
syso(iterator.next().name);
}
class Person{
String name;
int age;
//构造方法
public Person(String name,int age){
super();
this.name=name;
this.age=age;
}
}
class Dog{
}
*******************************************************
*
* 三个工厂
* 一个工厂只能实习生
* 一个工厂只能工人
* 一个工厂只能老板
*
* 当类型不确定时,想起泛型
*
* 1.泛型在类中的体现, 类在创建对象的时候把类型确定下来
* 2.泛型在方法中的体现
* 3.泛型在静态方法中的体现,不能去访问类中的泛型
* 4.泛型在接口上的体现
* 要么在实现类的时候确定,要么在创建对象的时候确定
* ******
*******************************************************************
* ******在设计类或者接口或方法时,如果类型不确定的时候,使用泛型***
* ****** 但是在使用的时候一定要确定类型,默认会认为object ***
* */***************************************************************
public class Demo2 {
public static void main(String[] args) {
//创建对象的时候 student 传给下面的<T> 所以<S>不是Student(泛型在方法中的体现)
//类型传的Student 确定类型 <T>是 <Student>
Factory<Student> f1 = new Factory<Student>();
f1.add(new Student());//只能传Student
//类型传的是<Worker>
Factory<Worker> f2 = new Factory<Worker>();
f2.add(new Worker());
//这个add1 传的可以就不是Worker类型 所以不报错 (因为泛型在方法中的应用)
f2.add1(new Student());
//泛型在接口中的体现
InterImpl<Worker> ii = new InterImpl();
}
}
//类型不确定的时候 写大写<T> 传什么就是什么↑↑↑
class Factory<T>{
public void add(T t){
}
//这个S不是student 对应上面的add1 可以不用类泛型指定的类型
public <S> void add1(S s){
T t; //不会报错 可以访问类中的泛型
}
//泛型在静态方法中的体现,不能去访问类中的泛型
public static <S> void add1(S s){
T t;
}
}
class Worker{}
class Student{}
class Boss{}
//泛型在接口中的体现
interface Inter<T>{
void add(T t);
}
class InterImpl<T> implements Inter<T>{
@Override
public void add(T t) {
}
}
Arraylist<Person> l=new Arraylist<Person>(); // 确定类型 集合只能存放Person对象
al.add(new Person("zhangsan",20)); //不会报错
//al.add("aaa"); //报错
//al.add(new Dog()) //报错
//加了泛型 迭代器不需要强转了
Iterator<Person>iterator=al.iterator();
while(iterator.hasNext()){
syso(iterator.next().name);
}
class Person{
String name;
int age;
//构造方法
public Person(String name,int age){
super();
this.name=name;
this.age=age;
}
}
class Dog{
}
*******************************************************
*
* 三个工厂
* 一个工厂只能实习生
* 一个工厂只能工人
* 一个工厂只能老板
*
* 当类型不确定时,想起泛型
*
* 1.泛型在类中的体现, 类在创建对象的时候把类型确定下来
* 2.泛型在方法中的体现
* 3.泛型在静态方法中的体现,不能去访问类中的泛型
* 4.泛型在接口上的体现
* 要么在实现类的时候确定,要么在创建对象的时候确定
* ******
*******************************************************************
* ******在设计类或者接口或方法时,如果类型不确定的时候,使用泛型***
* ****** 但是在使用的时候一定要确定类型,默认会认为object ***
* */***************************************************************
public class Demo2 {
public static void main(String[] args) {
//创建对象的时候 student 传给下面的<T> 所以<S>不是Student(泛型在方法中的体现)
//类型传的Student 确定类型 <T>是 <Student>
Factory<Student> f1 = new Factory<Student>();
f1.add(new Student());//只能传Student
//类型传的是<Worker>
Factory<Worker> f2 = new Factory<Worker>();
f2.add(new Worker());
//这个add1 传的可以就不是Worker类型 所以不报错 (因为泛型在方法中的应用)
f2.add1(new Student());
//泛型在接口中的体现
InterImpl<Worker> ii = new InterImpl();
}
}
//类型不确定的时候 写大写<T> 传什么就是什么↑↑↑
class Factory<T>{
public void add(T t){
}
//这个S不是student 对应上面的add1 可以不用类泛型指定的类型
public <S> void add1(S s){
T t; //不会报错 可以访问类中的泛型
}
//泛型在静态方法中的体现,不能去访问类中的泛型
public static <S> void add1(S s){
T t;
}
}
class Worker{}
class Student{}
class Boss{}
//泛型在接口中的体现
interface Inter<T>{
void add(T t);
}
class InterImpl<T> implements Inter<T>{
@Override
public void add(T t) {
}
}
阅读全文
0 0
- <泛型>的认识
- C#泛型(一) 泛型的认识
- Object、T(泛型)、?的认识
- 认识C++的类
- CSS的基本认识
- pageContext的认识
- 认识BLOG的技术
- 软件工程的认识
- 认识服务器的内存
- 工作流的新认识
- Yahoo!--新的认识
- 对句柄的认识
- 对句柄的认识
- 指针的初步认识!
- 对句柄的认识
- 工作的认识
- 对句柄的认识
- 认识.NET的集合
- kotlin Unable to instantiate activity ComponentInfo
- 【设计模式】策略模式
- 利用Azure搭建自己的个人网站 ————ONE
- 建造者模式--一种更好的方法去装配复杂的实例
- springboot的错误页面设置
- <泛型>的认识
- 自定义String类
- 初学 linux NFS
- poj3974 Palindrome(manacher)
- LintCode :Big Integer Addition
- 数据结构:链表栈
- POJ3133 Manhattan Wiring(难题 较为复杂)
- 鼠标滚轮事件之支付宝案例
- ICG博弈游戏的必胜策略