存储各子类的对象的ArrayList数组

一、源码示例

废话不说,上代码。

package animal;

import java.util.ArrayList;

public class Animal{
	String Class;
	
	public void Show() {
		System.out.println("类名:"+Class);
	}
	
	public static void main(String[] args) {
		/*这是一个能够存储猫猫狗狗的数组*/
		ArrayList<Animal> A = new ArrayList<Animal>();
		A.add(new Dog());
		A.add(new Cat("汤姆"));
		/*遍历展示对象数组A*/
		for(Animal a:A) {
			a.Show();
			/*检测类型:
			 * 当a是Dog类的实例时
			 * 执行Dog类对象独有的Bark()方法
			 * 如果是Cat类的实例
			 * 就输出Cat类对象独有的name成员
			 * */
			if(a instanceof Dog)
				((Dog) a).Bark();
			if(a instanceof Cat)
				System.out.println("我叫"+((Cat) a).name);
		}
	}
}
package animal;

public class Dog extends Animal{

	Dog() {
		// TODO 自动生成的构造函数存根
		Class="狗";
	}
	
	public void Bark() {
		System.out.println("汪汪汪");
	}

}
package animal;

public class Cat extends Animal{
	
	String name;
	
	Cat(String n) {
		name=n;
		// TODO 自动生成的构造函数存根
		Class="猫";
	}

}

运行结果:

类名:狗
汪汪汪
类名:猫
我叫汤姆
 

二、讲解

        ArrayList<T>可以存储类型为T的对象,T为父类时,可以存储T的各种子类的对象。这么做的好处就是,你可以把同属于动物类的猫、狗都放入数组,并且方法和成员变量不受影响(强转后)。

  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中数组和集合都是用来存储数据的数据结构,但它们各自有优缺点。 数组的优点是: 1. 快速访问:数组中的元素可以通过索引值快速访问,时间复杂度为O(1)。 2. 内存连续:数组中的元素在内存中是连续存储的,因此对于需要频繁访问的数据,数组的效率更高。 3. 多维数组数组可以是多维的,可以方便地表示矩阵等数据结构。 数组的缺点是: 1. 长度固定:数组的长度在创建时就已经确定,无法动态扩展或缩小。 2. 插入和删除元素困难:由于数组的长度固定,插入和删除元素需要移动其他元素,效率较低。 3. 只能存储同一类型的数据:数组中只能存储同一类型的数据,无法存储不同类型的数据。 集合的优点是: 1. 动态扩展:集合的长度可以动态扩展或缩小,可以根据需要动态地添加或删除元素。 2. 插入和删除元素方便:由于集合的长度可以动态扩展或缩小,插入和删除元素比数组更加方便。 3. 可以存储不同类型的数据:集合可以存储不同类型的数据,比数组更加灵活。 集合的缺点是: 1. 访问元素效率较低:由于集合中的元素是通过链表或树等数据结构存储的,访问元素的时间复杂度为O(n)。 2. 内存不连续:集合中的元素在内存中是不连续存储的,因此对于需要频繁访问的数据,效率较低。 3. 不支持多维:集合只能是一维的,无法方便地表示矩阵等数据结构。 Java中的集合类有很多类,每个类都有自己的特点和用途。比如: 1. ArrayList:基于数组实现,支持动态扩展,适合随机访问元素。 2. LinkedList:基于链表实现,支持快速插入和删除元素,适合频繁插入和删除元素。 3. HashSet:基于哈希表实现,支持快速查找元素,但元素的顺序不确定。 4. TreeSet:基于红黑树实现,支持有序查找元素。 5. HashMap:基于哈希表实现,支持快速查找键值对,但键值对的顺序不确定。 6. TreeMap:基于红黑树实现,支持有序查找键值对。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值