当前位置: 首页 > news >正文

电子商务网站建设与管理最新试卷重庆网站seo费用

电子商务网站建设与管理最新试卷,重庆网站seo费用,wordpress 模板 外贸,网站建设的合同 体会数组与泛型有很大的不同: 1. 数组是协变的(covariant) 意思是:如果Sub是Super的子类型,则数组类型Sub[] 是数组类型Super[] 的子类型。 2. 泛型是不变的(invariant) 对于任何两种不同的类型Ty…

数组与泛型有很大的不同:

1. 数组是协变的(covariant)
意思是:如果Sub是Super的子类型,则数组类型Sub[] 是数组类型Super[] 的子类型。

2. 泛型是不变的(invariant)
对于任何两种不同的类型Type1 和Type2,List<Type1> 既不是List<Type2> 的子类型也不是父类型。

现在有两段代码:

Object[] objectArray = new Long[1];
objectArray[0] = "I don't fit in"; 
List<Object> ol = new ArrayList<Long>(); // Incompatible types
ol.add("I don't fit in");

无论哪种方式都会报错,因为不能把一个String 类型放到一个Long 类型容器中,但是用一个数组的话,在运行时才会报错;对于列表,可以在编译时就能发现错误。所以使用列表就有优势,因为运行时报错的代价太高

3. 数组是具体化的,在运行时才知道和强化他们的类型

就比如上面的代码,将String保存到Long数组中就会得到ArrayStoreException异常

4. 泛型在编译时就强化它的类型信息,并在运行时擦除它的元素类型信息

由于上面这些区别,数组和泛型不能很好地混用,所以new List<E>[]new List<String>new E[]这些语法都是错误的!在编译时会产生一个泛型数组创建错误。

非法的原因是它不安全,以下面这段代码为例:

List<String>[] stringLists = new List<String>[1]; 	// (1)
List<Integer> intList = List.of(42); 				// (2)
Object[] objects = stringLists; 					// (3)
objects[0] = intList; 								// (4)
String s = stringLists[0].get(0); 					// (5)
  • 假设第1行创建一个泛型数组是合法的
  • 第2行创建并初始化包含单个元素的List<Integer>
  • 第3行将List<String> 数组存储到Object数组变量中,这是合法的,因为数组是协变的
  • 第4行将List<Integer> 存储在Object数组的唯一元素中,这是因为泛型是通过擦除来实现的:List<String>[] 实例是List[],所以这个赋值不会产生ArrayStoreException 异常

现在问题就来了,我们将一个List<Integer> 实例存储到一个声明为List<String> 实例的数组中,为了防止这种情况出现,第一行必须报错。

E,List<E> 和List<String> 等在技术上被称为不可具体化的类型,指其运行时表示法包含的信息比它的编译时表示法包含的信息更少。唯一可具体化的参数化类型是无限制的通配符类型,如List<?>等,创建无限制通配符类型的数组是合法的,但并不常用。


当泛型数组创建错误时,最佳解决方案是使用集合类型List<E> 。例如编写一个带有集合的Chooser类和一个方法,方法返回集合中随机选择的一个元素。

public class Chooser {private final Object[] choiceArray;public Chooser(Collection choices) {choiceArray = choices.toArray();}public Object choose() {Random rnd = ThreadLocalRandom.current();return choiceArray[rnd.nextInt(choiceArray.length)];}public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("1");list.add("2");list.add("3");Chooser chooser = new Chooser(list);Object choose = chooser.choose();System.out.println(choose);}
}

如果想将choose方法的返回值从Object转换成每次调用该方法时想要的类型

public class Chooser<T> {private final T[] choiceArray;public Chooser(Collection<T> choices) {choiceArray = choices.toArray();}// choose 方法不变
}

 上面的类会报错:

 如果加一条强制类型转换的话:

choiceArray = (T[]) choices.toArray();

仍有报警信息:

 要消除上面的警告,需要用列表代替数组:

public class Chooser<T> {private final List<T> choiceList;public Chooser(Collection<T> choices) {choiceList = new ArrayList<>(choices);}public T choose() {Random rnd = ThreadLocalRandom.current();return choiceList.get(rnd.nextInt(choiceList.size()));}
}

总结一下,数组和泛型有着截然不同的类型规则:
1. 数组是协变且可以具体化的
2. 泛型是不可变的且可以被擦除的

http://www.ds6.com.cn/news/46593.html

相关文章:

  • 做网站走啥科目百度图片查找
  • 2015手机版网站制作推广文案范文100字
  • 做彩票的网站吗网络运营是做什么的工作
  • wordpress影视主题mibt重庆seo和网络推广
  • 网站建设功能需求搜索量查询百度指数
  • wordpress和阿里云安徽网络seo
  • 阿里巴巴国际站运营模式嘉兴关键词优化报价
  • 网站平台建设方案策划书百度产品有哪些
  • 阿凡达营销网站网站排名推广推荐
  • 网站稳定期怎么做百度app下载并安装
  • 动态网站托管深圳排名seo
  • 做网站安全维护是什么东东软文兼职
  • 贵阳有做网站的公司吗seo网络优化软件
  • 免费自助开通网站网站推广的目的是什么
  • 品牌网站建设1毛尖网站推广排名服务
  • 医药招商网站大全免费成人计算机培训机构哪个最好
  • 移动网站建设的前景广告推广文案
  • 有了虚拟主机怎么做网站广告联盟推广
  • 网站怎么做飘窗网页搜索引擎优化技术
  • 荆州网站建设网站页面优化方案
  • 十里河网站建设百度地图打车客服人工电话
  • 国外网站布局百度2022第三季度财报
  • 网站的费用多少新闻稿营销
  • 网站设计公司杭州营销托管全网营销推广
  • 上海做网站比较有名的公司有哪些保定网站制作
  • 建设一批适合青少年的网站佛山网站建设模板
  • 论坛北京做网络优化的公司
  • 做装饬在哪家网站挂网站友情链接美化代码
  • 锦州网站建设品牌seo网站优化软件
  • 网站建设招聘需求设计师网站