java泛型学习记录

    百度百科对java泛型的定义:Java 泛型的参数只可以代表类,不能代表个别对象。由于 Java 泛型的类型参数之实际类型在编译时会被消除,所以无法在运行时得知其类型参数的类型。

    在se5中,java加入泛型,它实现了参数化类型的概念(将类型由原来的具体的类型参数化,也就是说在泛型使用过程中,操作的数据类型被指定为一个参数),基本类型无法作为类型参数。

    泛型类:在类的定义中加入泛型如public class Rlist<T> {}。我们通过对list集合的使用可以让我们这样去理解泛型类,当我们希望构建一个可以应用于各种类型的list集合时,我们就可以创建List<T>这个泛型类。当你为T参数类型时,那么你存入数据类型必须是这个T类型,当没指定时你可以往集合存入任何类型的数据。因此当我们想要构建一个可以应用于各种类型的抽象工具,就可以使用泛型类。看过jeesite的人可以知道,他是把许多基类都定义为抽象泛型类,让你的具体类去继承这个类以便让这个另类具有某些方法。下面是一个可以应用于各种类型集合获取其中随机数据的抽象类。

//获取list集合中随机数据
public class RandomList<T> {
    private List<T> storage = new ArrayList<T>();
//用于生成随机数
    private Random random = new Random(46);
    public void add(T item){storage.add(item);}
    public T select(){
//获取随机值
        return storage.get(random.nextInt(storage.size()));
    }

    public static void main(String[] args) {
//这里我们存入string类型
        RandomList<String> rs = new RandomList<String>();
        for (String s:("The quick brown fox jumped over").split(" ")) {
            rs.add(s);
        }
//当然你也可以向下面这样存入Integer类型
        /*RandomList<Integer> rs = new RandomList<Integer>();
        for (String s:("1 2 3 4 5 6").split(" ")) {
            rs.add(Integer.valueOf(s));
        }*/

        for (int i=0;i<6;i++){
            System.out.println(rs.select()+ " ");
        }
    }
}

       泛型接口:接口使用泛型和类使用泛型没什么区别,当你想要构建一个应用于各种类型的接口时就可以永泛型接口。

下面是个用于求某种运算值的代码

//泛型接口
public interface Generator<T> {
    T next();
}
//用于求值的实现
public class Fibonacci implements Generator<Integer> {
    private int count = 0;
    @Override
    public Integer next() {
        return fib(count++);
    }
    private int fib(int n){
        if (n < 2)
            return 1;
        return fib(n-2) + fib(n-1);
    }

    public static void main(String[] args) {
       Fibonacci gen = new Fibonacci();
       for (int i=0;i<18;i++){
           System.out.println(gen.next()+"");
       }
    }
}
//如果为此类实现Iterable,为避免代码重复这里使用适配器模式创建这个新类
//让他继承Fibonacci 然后实现Iterable,让Iterable的next方法
//适配IterableFibonacci的next就行
public class IterableFibonacci extends Fibonacci implements Iterable<Integer>{
    private int n;
    public IterableFibonacci(int count){n=count;}

    @Override
    public Iterator<Integer> iterator() {
        return new Iterator<Integer>() {
            @Override
            public boolean hasNext() {
                return n>0;
            }

            @Override
            public Integer next() {
                n--;
                return IterableFibonacci.this.next();
            }

            @Override
            public void remove() {

            }
        };
    }

    public static void main(String[] args) {
        for (int i:new IterableFibonacci(18)
             ) {
            System.out.println(i +"");
        }
    }
}

     泛型方法:

     要定义泛型方法只需将泛型参数列表置于返回值之前类似于 public <T> void f(T t){  };拥有泛型方法的类不一定时泛型类;当泛型方法可以替代整个类泛化,我们就使用泛型方法。我们调用泛型方法不需要向泛型类那样为其添加类型,编译器会为我们找出具体的类型当你为f方法传入1,会自动转为Integer,传入“1”会转为String。

 
 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
C语言是一种广泛使用的编程语言,它具有高效、灵活、可移植性强等特点,被广泛应用于操作系统、嵌入式系统、数据库、编译器等领域的开发。C语言的基本语法包括变量、数据类型、运算符、控制结构(如if语句、循环语句等)、函数、指针等。在编写C程序时,需要注意变量的声明和定义、指针的使用、内存的分配与释放等问题。C语言中常用的数据结构包括: 1. 数组:一种存储同类型数据的结构,可以进行索引访问和修改。 2. 链表:一种存储不同类型数据的结构,每个节点包含数据和指向下一个节点的指针。 3. 栈:一种后进先出(LIFO)的数据结构,可以通过压入(push)和弹出(pop)操作进行数据的存储和取出。 4. 队列:一种先进先出(FIFO)的数据结构,可以通过入队(enqueue)和出队(dequeue)操作进行数据的存储和取出。 5. 树:一种存储具有父子关系的数据结构,可以通过中序遍历、前序遍历和后序遍历等方式进行数据的访问和修改。 6. 图:一种存储具有节点和边关系的数据结构,可以通过广度优先搜索、深度优先搜索等方式进行数据的访问和修改。 这些数据结构在C语言中都有相应的实现方式,可以应用于各种不同的场景。C语言中的各种数据结构都有其优缺点,下面列举一些常见的数据结构的优缺点: 数组: 优点:访问和修改元素的速度非常快,适用于需要频繁读取和修改数据的场合。 缺点:数组的长度是固定的,不适合存储大小不固定的动态数据,另外数组在内存中是连续分配的,当数组较大时可能会导致内存碎片化。 链表: 优点:可以方便地插入和删除元素,适用于需要频繁插入和删除数据的场合。 缺点:访问和修改元素的速度相对较慢,因为需要遍历链表找到指定的节点。 栈: 优点:后进先出(LIFO)的特性使得栈在处理递归和括号匹配等问题时非常方便。 缺点:栈的空间有限,当数据量较大时可能会导致栈溢出。 队列: 优点:先进先出(FIFO)的特性使得
该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 该资源内项目源码是个人的课程设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

子鞋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值