toArray()与toArray(T [] a)的区别「建议收藏」

toArray()与toArray(T [] a)的区别「建议收藏」1、Object[]toArray()原理:将集合转换为Object类型的数组并返回该数组(以首地址的形式)。 调用格式:Object[]a=collecton.toArray() 注意:(1)前面类型必须为Object[]且不能被强制转换。(2)需要在遍历Objecta[]时,再强制转换a[n]的类型。由于编译器在语法上无法检测到类型错误,容易

大家好,又见面了,我是你们的朋友全栈君。

1、Object[] toArray()
原理:将集合转换为Object类型的数组并返回该数组(以首地址的形式)。 

调用格式: Object []a=collecton.toArray() 

注意:(1)前面类型必须为Object[]且不能被强制转换。
           (2)需要在遍历Object a[]时,再强制转换a[n]的类型。由于编译器在语法上无法检测到类型错误,容易出现类型使用不当。

附注:
collection.toArray()是旧式的获得对象数组的方法。

在java5引入泛型之前,这是唯一的获得对象数组的方法。



2、<T> T[] toArray(T[] a)
原理:根据参数数组的类型,构造了一个与向量元素个数相等的空数组。
调用格式: 
(1)String a[] = collection.toArray(new String[0]);//将collection中的内容保存到数组a中。
(2)return collection.toArray(new String[0])//若数组容量太小,将自动重新分配一个数组。
这个方法安全,明确。
(3)String s[] = collection.toArray(new String[collection.size()]);//姑且认为是最好的使用方式。
附注:toArray(T[] a)是Java5 引入泛型模板机制后的新调用方法。区别就是明确了类型。
如果Collection在创建时明确了类型,比如Collection<String>,这里的方法也有了相应的类型。编译器可以检测到类型错误。

代码示例:
public class RandomTeacher {
	private static String[] getRandomteachers(String[] teachers, int n) {
		Vector<String> vName = new Vector<String>();

		for (int i = 0; i < n; i++) {
			while (true) {
				Random random = new Random();

				int index = random.nextInt(teachers.length - 1);
				if (vName.contains(teachers[index]) == false) {
					vName.add(teachers[index]);
					break;
				}
			}
		}
		//1.
//		return vName.toArray(new String[1]);//以空数组作为参数
		
		//2.
//		String [] choosedTeacher = new String[3];//当空间不够用时,toArray(T[] a)会自动分配一个新的数组
//		vName.toArray(choosedTeacher);

		//3.姑且认为是最好的。
		return vName.toArray(new String[vName.size()]);
	}

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String teachers[] = { "张", "赵", "刘", "钱", "孙", "李", "周", "吴", "郑", "王" };
		String[] choosedTeachers = RandomTeacher.getRandomteachers(teachers, 5);
		for (int i = 0; i < choosedTeachers.length; i++)
			System.out.println("teacher " + (i + 1) + " : "+ choosedTeachers[i]);

	}

}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/146524.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 网站优化怎样的外链能轻松收录,网站外链优化攻略「建议收藏」

    网站优化怎样的外链能轻松收录,网站外链优化攻略「建议收藏」有些事情,让你感到很无奈,网站外链优化也是如此,往往那些很容易发布网站外链的地方,价值不大,而不容易发布外链的地方,一旦发布上去了,效果胜过几十条甚至更多的外链,而且可以轻松让搜索引擎收录,网站优化怎样让网站外链轻松被收录呢?<ignore_js_op>一、善于寻找我们运营的是网站,发布外链的地方也是网站,除了内容有差异之外,权重高低也有差别,我们要找的自然是高于我们权重的网站,…

    2022年7月21日
    15
  • jboss版本_输入法下载

    jboss版本_输入法下载昨天和今天到jboss区下载jboss4.0.4或者其他版本,没有一个下的了,太烂了,网站怎能这样,现在是什么时代呀,免费的或者收费的服务都应该要做的很好才是.感觉现在的软件的功能远远没有达到我心目中理想的位置,也不知何年何月我才对会软件的功能称好!也许软件就是这样吧,开发要成本,做得很好是几乎不可能的了.

    2022年9月28日
    3
  • windows copy命令详解

    windows copy命令详解将一份或多份文件复制到另一个位置 COPY D V N Y Y Z A B source A B source A B destination A B source 指定要复制的文件 A 表示一个 ASCII 文本文

    2025年7月31日
    5
  • 一代、二代、三代测序技术原理与比较「建议收藏」

    一代、二代、三代测序技术原理与比较「建议收藏」从1977年第一代DNA测序技术(Sanger法)1,发展至今三十多年时间,测序技术已取得了相当大的发展,从第一代到第三代乃至第四代,测序读长从长到短,再从短到长。虽然就当前形势看来第二代短读长测序技术在全球测序市场上仍然占有着绝对的优势位置,但第三和第四代测序技术也已在这一两年的时间中快速发展着。测序技术的每一次变革,也都对基因组研究,疾病医疗研究,药物研发,育种等领域产生巨大的推动作用。在这里我主要对当前的测序技术以及它们的测序原理做一个简单的小结。

    2022年5月17日
    92
  • ros的安装教程_ros可以安装在什么系统

    ros的安装教程_ros可以安装在什么系统一、准备工作1. 一个装有Ubuntu14.04镜像文件的U盘启动盘2. 电脑安装EASYBCD、分区助手软件3. 保证电脑硬盘有一个分区有足够的空间安装ROS,和Ubuntu14.04二、制作启动盘1.首先我们先安装软碟通,完成安装后打开软碟通,文件-&gt;打开,打开我们的iso镜像 2.然后选择我们的U盘,然后点击启动-&gt;写入硬盘映像  3.写入方式有zip和hdd两种,一般我们选择h…

    2022年9月11日
    2
  • webstorm关闭eslint检测

    webstorm关闭eslint检测vue项目已经设置关闭eslint,但是代码还是很多标红线的地方,原因是webstorm这个ide默认启用了eslint,可以在设置中关闭把Enable的勾去掉即可

    2022年5月2日
    66

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号