泛型

命名规则

问题引入

package practice;
class Point{
    private Object x;
    private Object y;
    public void setX(Object x) {
        this.x = x;
    }
    public Object getX() {
        return x;
    }
    public void setY(Object y) {
        this.y = y;
    }
    public Object getY() {
        return y;
    }
}
public class fanxing {
    public static void main(String []args){
        Point p = new Point();
        p.setX(10);
        p.setY(20);
        int x = (Integer)p.getX();   
        int y = (Integer)p.getY();
        System.out.println("X的坐标:"+x+";"+"Y的坐标:"+y);
    }
}
---------------------------------
package practice;
class Point{
    private Object x;
    private Object y;
    public void setX(Object x) {
        this.x = x;
    }
    public Object getX() {
        return x;
    }
    public void setY(Object y) {
        this.y = y;
    }
    public Object getY() {
        return y;
    }
}
public class fanxing {
    public static void main(String []args){
        Point p = new Point();
        p.setX(10);
        p.setY("20");  //如果不用泛型,两个互不相干的类会出现
Exception in thread "main" java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Integer
    at practice.fanxing.main(fanxing.java:24)的错误
        int x = (Integer)p.getX();   
        int y = (Integer)p.getY();
        System.out.println("X的坐标:"+x+";"+"Y的坐标:"+y);
    }
}

泛型引入

package practice;
class Point<T>{
    private T x;
    private T y;
    public void setX(T x) {
        this.x = x;
    }
    public T getX() {
        return x;
    }
    public void setY(T y) {
        this.y = y;
    }
    public T getY() {
        return y;
    }
}
public class fanxing {
    public static void main(String []args){
        Point<String> p = new Point<String>();  //<String>只能是引用数据类型,不能是基本数据类型
        p.setX("10");
        p.setY("20");
        String x = p.getX();
        String y = p.getY();
        System.out.println("X的坐标:"+x+";"+"Y的坐标:"+y);
    }
}

如果使用泛型类或接口的时候,用Object

package practice;
class Point<T>{
    private T x;
    private T y;
    public void setX(T x) {
        this.x = x;
    }
    public T getX() {
        return x;
    }
    public void setY(T y) {
        this.y = y;
    }
    public T getY() {
        return y;
    }
}
public class fanxing {
    public static void main(String []args){
        Point p = new Point();   //统一Object
        p.setX("10");
        p.setY("20");
        String x = (String)p.getX();   //需转型
        String y = (String)p.getY();    //需转型
        System.out.println("X的坐标:"+x+";"+"Y的坐标:"+y);
    }
}

通配符

package practice;
class Point<T>{
    private T x;
    public void setX(T x) {
        this.x = x;
    }
    public T getX() {
        return x;
    }
}
public class fanxing {
    public static void main(String []args){
        Point<String> p = new Point<String>();
        p.setX("Hello World!!!");
        fun(p);
    }
    public static void fun(Point<String> m){    //Point<String> m 中的Ponit需要与类名一致
        System.out.println(m.getX());
    }
}

不设置方法类型

package practice;
class Point<T>{
    private T x;
    public void setX(T x) {
        this.x = x;
    }
    public T getX() {
        return x;
    }
}
public class fanxing {
    public static void main(String []args){
        Point<Integer> p = new Point<Integer>();
        p.setX(30);
        fun(p);
    }
    public static void fun(Point m){  //去掉<Integer>,解决不同参数类型的影响
        System.out.println(m.getX());
    }
}

泛型接口

定义接口泛型

package cn.fovegage.prac;
interface IMessage<T>{
    public void print(T t);
}
public class FanXing {
    public static void mian(String []args){
        
    }
}

在子类继续设置泛型

package cn.fovegage.prac;

interface IMessage<T>{
    public void print(T t);
}
class MessageImpl<T> implements IMessage<T>{
    @Override
    public void print(T t) {
        // TODO Auto-generated method stub
        System.out.println(t);
    }
}
public class FanXing {
    public static void main(String []args){
        IMessage<String> msg = new MessageImpl<String>(); 
        msg.print("Hello World!!!");
    }
}

在子类不设置泛型。而为父接口明确的定义一个泛型类型

package cn.fovegage.prac;

interface IMessage<T>{
    public void print(T t);
}
class MessageImpl implements IMessage<String>{
    @Override
    public void print(String t) {
        // TODO Auto-generated method stub
        System.out.println(t);
    }
}
public class FanXing {
    public static void main(String []args){
        IMessage<String> msg = new MessageImpl(); 
        msg.print("Hello World!!!");
    }
}

泛型方法

package cn.fovegage.prac;
public class FanXing {
    public static void main(String []args){
    String str = fun("Hello World!!!");
    System.out.println(str.length());
    }
    public static <T> T fun(T t){
        return t;
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • object 变量可指向任何类的实例,这让你能够创建可对任何数据类型进程处理的类。然而,这种方法存在几个严重的问题...
    CarlDonitz阅读 4,429评论 0 5
  • 一、为什么要使用泛型 1.类型参数的好处 类型安全:泛型的主要目标是提高 Java 程序的类型安全。通过知道使用泛...
    SeanMa阅读 11,936评论 1 18
  • 开发人员在使用泛型的时候,很容易根据自己的直觉而犯一些错误。比如一个方法如果接收List作为形式参数,那么如果尝试...
    时待吾阅读 4,676评论 0 3
  • 导语 这里是导语。对,没错,这里就是导语,没有前几次的代码情书。喜欢情书的关注我,去看我之前的Java文章吧。 主...
    一个有故事的程序员阅读 3,630评论 9 8
  • 别再我面前趾高气昂,你在我面前你什么也不是。只是你自己感觉良好罢了。 很多人因为自己有点钱,又或者地位高点,又...
    遨游于天际阅读 3,499评论 0 1