Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >具有泛型的数组的转换

具有泛型的数组的转换
EN

Stack Overflow用户
提问于 2013-08-24 08:42:50
回答 3查看 131关注 0票数 5

以下语句之间有什么区别:

代码语言:javascript
运行
AI代码解释
复制
List<E>[] x = (List<E>[]) new List[100];

代码语言:javascript
运行
AI代码解释
复制
List<E>[] x = new List[100];

在我的脚本中,注意到前者将是创建泛型数组的正确方法(尽管它会导致编译器警告)。但我不太清楚(List<E>[])语句的用途。List<E>[]甚至不是它自己的类型,编译器将简单地用(List[])替换它,所以

代码语言:javascript
运行
AI代码解释
复制
List<E>[] x = (List[]) new List[100];

List[]List[]的转换,这是无用的。那么,为什么首先要设置一个(List<E>[])呢?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-08-24 09:25:29

泛型通过使更多的bug在编译时可以检测到,从而增加了代码的稳定性。

这是我给出的链接的一部分,我认为这是很重要的,所以我在这里发布。

这是列表和包java.util中的Iterator定义的一个小片段: 公共接口列表{ void (E);Iterator迭代器();}公共接口Iterator {E next();布尔hasNext();} 这段代码应该是熟悉的,除了尖括号中的内容。这些是接口列表和Iterator的https://stackoverflow.com/questions/360766/java-formal-type-parameter-definition-generics声明。 类型参数可以在泛型声明中使用,几乎可以使用普通类型。 我们知道泛型类型声明列表的调用,例如列表。在调用(通常称为参数化类型)中,形式类型参数(在本例中为E)的所有出现都被实际类型参数(本例中为整数)所替换。 --您可能会想到,列表代表的是列表的一个版本,其中E已一致地被Integer替换:公共接口IntegerList { void (Integer);Iterator迭代器();} 这种直觉是有帮助的,但它也是误导。 这是有帮助的,因为参数化类型列表确实有类似于此展开的方法。 它具有误导性,因为泛型的声明从来没有以这种方式展开过。代码没有多个副本--不是在源代码中,不是二进制中,不是磁盘上,也不是内存中。 泛型类型声明被一劳永逸地编译,并转化为一个类文件,就像普通类或接口声明一样. 类型参数类似于方法或构造函数中使用的普通参数。就像方法具有描述其操作的值类型的形式值参数一样,泛型声明具有形式类型参数。当方法被调用时,实际的参数被替换为形式参数,并且方法体被求值。在调用泛型声明时,实际的类型参数将被替换为形式类型参数。这就是泛型的>重要性.. 你可以在这里寻找http://docs.oracle.com/javase/tutorial/extra/generics/intro.html

票数 3
EN

Stack Overflow用户

发布于 2013-08-24 09:58:18

这是:

代码语言:javascript
运行
AI代码解释
复制
List<E>[] x = new List[100];

说x是数组类型。该数组的元素是可以容纳类型E对象的列表。您将为其分配一个列表数组,该数组可以保存任何对象

下一份声明:

代码语言:javascript
运行
AI代码解释
复制
List<E>[] x = (List<E>[]) new List[100];

再好不过了。演员也帮不上忙。缺陷仍然是一样的。

最后,所有这些都是这样做的借口:

代码语言:javascript
运行
AI代码解释
复制
List<E>[] x =  new List<E>[100];

Java中不允许泛型数组。因为数组在运行时保留其元素类型,而一般构造则不保留。必须没有严格定义元素类型的数组。

问题在于定义了引用类型List<E>[],根据定义,它不允许在Java中实例化。所以,避免使用这类类型。

您可以使用列表作为替代方案。

票数 1
EN

Stack Overflow用户

发布于 2013-08-24 09:59:07

与泛型一样,存储在任何集合中的对象类型将在将其添加到集合时进行类型检查。主要通过泛型,代码可以被其他不需要知道泛型的人理解。因此,通过在编译时插入检查,并在运行时擦除,可以实现这种行为。

你可以看到:http://docs.oracle.com/javase/tutorial/java/generics/

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18420797

复制
相关文章
React:Redux怎么处理异步?
redux-thunk 中间件允许你 dispatch 一个函数(即:thunk),异步逻辑就放在这个函数中处理;
WEBJ2EE
2019/07/19
2.7K0
React:Redux怎么处理异步?
React---Redux异步action
(2).何时需要异步action:想要对状态进行操作,但是具体的数据靠异步任务返回。
半指温柔乐
2021/05/06
8600
Redux 异步数据流初探
用React写的项目中各组件的状态依赖关系非常复杂,为了便于管理组件的状态,使用 Redux。
一个会写诗的程序员
2018/12/13
6340
Redux 异步数据流初探
React-Redux 源码解析系列 -- React-Redux的作用
前面的章节讲完了redux的部分,又已经有了react,那为什么还需要有React-Redux呢?这个React-Redux 又帮助我们做了什么呢?
IMWeb前端团队
2019/12/03
7950
React-Redux 源码解析系列 -- React-Redux的作用
React-Redux 源码解析系列 -- React-Redux的作用
摘要总结:本文介绍了React-Redux的代码架构和设计理念,通过代码示例和示意图解释了React-Redux的代码结构和流程。同时,文章还探讨了React-Redux的优缺点,包括连接react和redux的方式、高阶组件的使用、纯组件的使用等。通过本文的讲解,可以更好地理解React-Redux的工作原理和架构设计,对于学习和使用React-Redux具有很高的参考价值。
IMWeb前端团队
2017/12/29
1K0
React-Redux 源码解析系列 -- React-Redux的作用
React:redux-form 应用示例
redux-form 提供了一堆 selector,便于我们从state中获取 form 表单的各种状态数据...
WEBJ2EE
2019/07/19
7180
React:redux-form 应用示例
Redux异步解决方案 1. Redux-Thunk中间件
简单介绍一下thunk,这是一个中间件,是解决redux异步问题产生的。我们都知道,在使用redux的时候,通过dispatch一个action 发生到reducer 然后传递给store修改状态 一系列都是同步的,那如果说我dispatch一个action 这个action帮我请求一下接口数据,你发现接口请求是异步的,没有办法等接口数据返回再传递给reducer 这个时候中间件就产生啦。 redux比较常用的中间件有 redux-saga、redux-thunk、redux-promise等 都是为了解决dispatch action异步处理问题
憧憬博客
2020/07/21
1.3K0
Redux 异步解决方案2. Redux-Saga中间件
因为Generator。结合yield  yield操作符会获取右边表达示的值返回 可以用于异步变同步操作 中间件的特性: 以前的 action -> reducers -> store 现在的 action -> middleware -> reducers -> store
憧憬博客
2020/07/21
1.1K0
Redux异步解决方案之Redux-Thunk原理及源码解析
前段时间,我们写了一篇Redux源码分析的文章,也分析了跟React连接的库React-Redux的源码实现。但是在Redux的生态中还有一个很重要的部分没有涉及到,那就是Redux的异步解决方案。本文会讲解Redux官方实现的异步解决方案----Redux-Thunk,我们还是会从基本的用法入手,再到原理解析,然后自己手写一个Redux-Thunk来替换它,也就是源码解析。
蒋鹏飞
2020/10/15
3.6K0
前端实现异步的几种方式_redux是什么
实际上,这个术语出自康奈尔大学的一篇论文:http://www.cs.cornell.edu/andru/cs711/2002fa/reading/sagas.pdf
全栈程序员站长
2022/10/02
1.8K0
前端实现异步的几种方式_redux是什么
异步发送邮件完整示例
本章使用task异步进程进行邮件发送,来阐述一下以上章节提到的各个知识点。 邮件类 下载swiftmailer composer require "swiftmailer/swiftmailer:^6.0" Mailer.php 与 vender目录 同级 require_once __DIR__ . '/vendor/autoload.php'; class Mailer { public $transport; public $mailer; /** * 发送邮件类
码农编程进阶笔记
2021/07/20
6710
异步发送邮件完整示例
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/111876.html原文链接:https://javaforall.cn
全栈程序员站长
2022/07/11
6200
redux-thunk 中间件的示例
Redux处理异步任务——异步数据流中间件:redux-thunk & action是一个函数,函数内部处理异步任务
用户9914333
2022/07/22
5720
在 redux 应用中使用 GraphQL
在 Redux 应用中获取和管理数据需要做许多工作。正如 Sashko Stubailo 指出的:
疯狂的技术宅
2019/03/28
2K0
在 redux 应用中使用 GraphQL
【Redux】:Redux 指北
Redux 是JavaScript 应用的状态管理容器,提供集中式、可预测的状态管理。
WEBJ2EE
2021/06/15
1.6K0
深入学习 Redux 之中间件与异步操作
上一节,学习了 Redux 的基本用法:用户发出 Action,Reducer 函数算出新的 State,View 重新渲染。
Leophen
2021/07/23
1.1K0
Redux 入门教程(二):中间件与异步操作
上一篇文章,我介绍了 Redux 的基本做法:用户发出 Action,Reducer 函数算出新的 State,View 重新渲染。 但是,一个关键问题没有解决:异步操作怎么办?Action 发出以后
ruanyf
2018/04/12
1.6K0
Redux 入门教程(二):中间件与异步操作
点击加载更多

相似问题

在Firefox上不起作用

10

在firefox上不起作用

11

print()在Firefox上不起作用

14

tinymce在firefox上不起作用

20

空格在Firefox上不起作用

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档