07.Java基础(泛型)
在类上定义泛型
类上定义的泛型是在对象实例化的时候指定的,可以用于类中定义的成员变量和成员方法,但是不包括静态成员变量和静态成员方法,因为静态变量和方法的调用可以通过类名实现,不需要创建类的对象,因此此时类上定义的泛型还没有被指定,所以静态不能使用类定义的泛型,相反对于普通成员变量和方法,它们的调用是通过类的对象来实现地,创建对象之后泛型已经被指定,所以它们可以和类的泛型保持一致
public class Tool<R> { //Cannot make a static reference to the non-static type R //public static R r; public R r; public void setR(R r) { this.r = r; } public R getR() { return r; } }
在方法上定义泛型
方法上使用的泛型可以和类泛型保持一致,比如我们上边得到setR getR方法,也可以设置和类泛型不同的泛型,如下便setParam方法泛型Z的指定,这样在调用这个方法的时候就可以你指定什么泛型就设置什么类型,但是这样操作似乎意义不大,方法泛型最好和类泛型保持一致
public class Tool<R> { public R r; public void setR(R r) { this.r = r; } public R getR() { return r; } //这种使用形式会报错:Z cannot be resolved to a type //因为Z泛型并没有被定义,正确的方式是下边 //public void setParam(Z z) { //}; //把泛型指定在方法返回值类型的前边,注意不可以是后边 public <Z>void setParam(Z z) { }; }
在静态方法上使用泛型
静态方法随着类的加载就已经存在,所以先于对象的创建,因此不能使用类上定义的泛型,类泛型是在创建对象的时候指定的,静态方法泛型在调用静态方法的时候指定
public class Tool<R> { public R r; public void setR(R r) { this.r = r; } public R getR() { return r; } //public void setParam(Z z) { //}; public <Z>void setParam(Z z) { }; //同样这种使用形式会报错:M cannot be resolved to a type //因为Z泛型并没有被定义,正确的方式是下边 //public static void setData(M m) { //} //静态方法的泛型要定义在返回值的左边,static关键字的右边 public static <M>void setData(M m) { } }
在接口上使用泛型
在接口上定义泛型的目的很简单,就是对实现类做限制,保证规则的统一
定义接口中所有方法都可以使用的泛型,接口中可能存在多个方法,这样一来每个方法都可以使用这个泛型
public interface Inter<R> { void process(R r); } class Demo implements Inter<String>{ @Override public void process(String r) { } }
针对接口中单独的方法指定独有的泛型
public interface Inter { <R>void process(R r); } class Demo implements Inter{ @Override public <R> void process(R r) { } }
接口中虽然定义了泛型,但是我操作实现类的时侯再指定这个实现类特定的泛型,这样做是可行的,但是没有实际意义
public interface Inter<R> { void process(R r); } class Demo<Z> implements Inter<Z>{ @Override public void process(Z r) { // TODO Auto-generated method stub } }
泛型通配符<?>
<?>表示任意类型,如果没有明确指定那就是Object以及任意的Java类
通配符的两种使用场景
?extends E : 向下限定,固定上边界,E及其子类
? super E :向上限定,固定下边界,E及其父类
向下限定,E及其子类
Colloection的addAll方法
addAll(Colloction<? extends E> c);
//student是person的子类,所以可以调用addAll方法添加 ArrayList<Person> list1 = new ArrayList<>(); ArrayList<Student> list2 = new ArrayList<>(); list1.addAll(list2);
向上限定,固定下边界,E及其父类
TreeMap构造方法
TreeMap(Comparator<? super K> comparator)
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
SQL Server 2008 R2——分组取前几名
版权声明:本文为博主原创文章 未经许可不得转载 请通过右侧公告中的“联系邮箱(wlsandwho@foxmail.com)”联系我 未经作者授权勿用于学术性引用。 未经作者授权勿用于商业出版、商业印刷、商业引用以及其他商业用途。 本文不定期修正完善,为保证内容正确,建议移步原文处阅读。 <--------总有一天我要自己做一个模板干掉这只土豆 本文链接:http://www.cnblogs.com/wlsandwho/p/4829125.html 耻辱墙:http://www.cnblogs.com/wlsandwho/p/4206472.html ======================================================================= 只是写个简单的例子,不要在意星号什么的。 1 USE tempdb 2 3 IF EXISTS(SELECT * FROM sysobjects WHERE id=OBJECT_ID(N't_Test') AND OBJECTPROPERTY(id,N'IsUserTable')=1) 4 ...
- 下一篇
python中的SQLite数据库
python中的SQLite数据库 Python SQLITE数据库是一款非常小巧的嵌入式开源数据库软件,也就是说没有独立的维护进程,所有的维护都来自于程序本身。它使用一个文件存储整个数据库,操作十分方便。它的最大优点是使用方便,功能相比于其它大型数据库来说,确实有些差距。但是性能表现上,SQLITE并不逊色。麻雀虽小,五脏俱全, sqlite 实现了多数 sql-92 的标准,比如说 transaction 、 trigger 和复杂的查询等。 下面让我们一步步走进Python中的SQLite吧。 一,Python SQLITE数据库导入模块: import sqlite3 二,创建数据库/打开数据库: cx = sqlite3.connect("E:/test.db") 其实我们不需要显式的创建一个sqlite数据库,在调用connect函数的时候,指定库名称,如果指定的数据库存在就直接打开这个数据库,如果不存在就新创建一个再打开。这一点应用很好理解。 三,数据库连接对象: 打开数据库时返回的对象cx就是一个数据库连接对象,它可以有以下操作: commit()–事务提交 roll...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS8编译安装MySQL8.0.19
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2全家桶,快速入门学习开发网站教程