ArrayList集合的创建与基本使用

package Demo_ArrayList;

import java.util.ArrayList;

/*
数组的长度不可以发生改变
但ArrayList的长度可以发生变化

对于ArrayList来说,有一个尖括号<E>代表泛型
泛型:也就是装在集合中的所有元素,全都是统一的某一类型
注意:泛型只能是引用类型,不能是基本类型
Java有八大基础类型:整型(byte,int,short,long,float,double),字符型(char),布尔型(boolean)。
引用数据类型:类(class), 接口(interface),数组(array),(枚举类型、注解类型、字符串(String)类型)
简单来说,只要不是基本数据类型.都是引用数据类型

注意:对于ArrayList集合来说,直接打印得到的不是地址值,而是内容
如果内容为空,得到的是中括号[]
 */
public class Demo02ArrayList {
    public static void main(String[] args) {
        //创建了一个ArrayList集合,集合名称是List,里面装的全都是Sreing字符串类型的数据
        //备注:从JDK 1.7+开始,右侧尖括号内部可以不写内容,但<>本身依然要写
        ArrayList<String> list  = new ArrayList<String>();
        System.out.println(list);//[]

        //向集合中添加数据,需要用add方法
        list.add("玊");
        System.out.println(list);//[玊]
        list.add("一");
        list.add("二");
        list.add("三");
        list.add("四");
        System.out.println(list);//[玊, 一, 二, 三, 四]

        //list.add(100);//错误!创建时,尖括号内部只能放String类型
    }
}

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
掌握集合的概念、体系结构、分类及使用场景 2)了解Set接口及主要实现类(HashSet、TreeSet) 3)了解List接口及主要实现类(ArrayList、LinkedList、Vector) 4)了解Map接口及主要实现类(HashMap、TreeMap、HashTable) 二、实验内容及步骤 1、编写程序练习将以下5个Person类的对象放在一个HashSet。 姓名:张三 身份证号:178880001 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880003 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880004 注意:因为Person类是自定义类,需要重写hashCode()方法和equals()方法,并规定只有姓名和身份证号都相等,则对象相等。 其计算哈希码的算法:(31 + ((name == null) ? 0 : name.hashCode()))*31 + id (注:name:Person对象的姓名,id:Person对象的身份证号) 主方法作如下测试: 1)创建一个可放置Person类对象的HashSet; 2)依次添加上述5个对象到HashSet; 3)把集合的元素打印出来(使用迭代器Iterator) 2、编写程序练习List集合基本使用: 1) 创建一个只能容纳String对象名为names的ArrayList集合; 2)按顺序往集合添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七"; 3)对集合进行遍历,分别打印集合的每个元素的位置与内容; 4)打印集合的大小,然后删除集合的第3个元素,并显示删除元素的内容,然后再打印目前集合第3个元素的内容,并再次打印集合的大小。 3、编写程序练习Map集合基本使用: 1)创建一个只能容纳String对象的person的HashMap集合; 2)往集合添加5个"键-值"对象: "id"-"1"; "name"-"张三"; "sex"-"男"; "age"-"25"; "hobby"-"爱学Java" 3)对集合进行遍历,分别打印集合的每个元素的键与值; 4)打印集合的大小,然后删除集合的键为age的元素,并显示删除元素的内容,并再次打印集合的大小。 四、思考题 1、集合的List、Set、Map有哪些不同? 2、为什么使用集合框架,而尽可能少用数组作为存储结构? 3、如何使用TreeSet实现第一题?

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值