ArrayList 集合

ArrayList 集合

ArrayList<String> list = new ArrayList<>();
  1. 对于ArrayList来说,有一个尖括号<E>代表泛型。
  2. 泛型:也就是也就是装在集合当中的所有元素,全部都是统一的什么类型
  3. 注意:泛型只能是引用类型,不能是基本类型

数组有一个缺点:一旦创建,程序运行期间长度不可以发生改变

ArrayList 集合和数组的区别:

  • 数组的长度不可以改变。
  • 但是ArrayList的长度可以改变。

注意事项:

  • 对于ArrayList集合来说,直接打印得到的不是地址值,而是内容。
  • 如果内容是空,得到的是空的中括:[]

ArrayList当中常用的方法:
public boolean add(E e):

  • 向集合当中添加元素,参数的类型和泛型一致。返回值代表添加是否成功。
  • 备注:对于ArrayList集合来说,add添加动作一定是成功的,所以返回值可用可不用。
  • 但是对于其他集合来,add添加的动作不一定成功。

public E get(int index);

  • 从集合当中获取元素,参加是索引编号,返回值就是对应位置的元素。
  • 索引值从零开始 E是泛型

public E remove(int index );

  • 从集合当中删除元素,参数就是索引编号,返回值就是被删除的元素。

public int size();

  • 获得集合尺寸的长度,返回值是集合中包含的元素个数。
ArrayList<int> list = new ArrayList<>();
//错误写法 泛型只能是引用类型,不能是基本类型

如果希望向集合ArrayList当中存储基本类型数据,必须使用基本类型对应的“包装类”。

基本类型---包装类(引用类型,包装类都位于java.lang包下)
byte---Byte
short---Short
int---Integer 【特殊】
long---Long
float---Float
double---Double
char---Character 【特殊】
boolean---Boolean

从JDK 1.5+开始,支持自动装箱、自动拆箱。

自动装箱:基本类型--->包装类型
自动拆箱:包装类型--->基本类型

题目:

生成6个1~33之间的随机整数,添加到集合并遍历集合。

思路:
1.需要存储6个数字,创建一个集合,<Integer>
2.产生随机数,需要用到Random
3.用循环6次,来产生6个随机数:for循环
4.循环内调用r.nextInt(int n),参数是33, 0~32,整体+1才是1~33
5.把数字添加到集合中:add
6.遍历集合:for,size,get

import java.util.Random
import java.util.Scanner public calss CaiNiao{ public static void mian(String[] args){ ArrayList<Integer> list = new ArrayList<>();
Random r = new Random();
for(int i = 0;i<6;i++){
int num = r.nextInt(33)+1;
list.add(num);
}
//遍历集合
for(int i = 0;i<list.size();i++){
System.out.println(list.get(i));
}
}
}

题目:

用一个大的集合存入20个随机数字,然后筛选其中的偶数元素,放到小集合当中。
要求使用自定义的方法来实现筛选。

分析:
1.需要创建一个大集合,用来存储int数字,<Integer>
2.随机数就是用Random nextInt
3.循环20次,把随机数字放入大集合:for循环,add方法
4.定义一个方法,用来筛选符合要求的元素,得到小集合
三要素:

  • 返回值类型:ArrayList小集合(里面元素个数不确定)
  • 方法名称:getSmallist
  • 参数列表:ArrayList大集合(装着20个随机数字)

5,判断(if)是偶数:num%2 = = 0
6.如果是偶数。就放到小集合当中,否则不放

import java.util.Random

public class CaiNiao{

    public static void main(String[] args){
ArrayList<Integer> biglist = new ArrayList<>();
Random r = new Random();
for(int i = 0;i<20;i++){
int num = r.nextInt(100)+1;//1~100
biglist.add(num);
}
ArrayList<Integer> smallList = getSmallist(biglist); System.out.println("偶数总共有多少个:" + smallList.size());
for(int i = 0;i<smallList.size();i++){
System.out.println(smallList.get(i));
}
}
//这个方法,接受大集合参数,返回小集合结果
public static ArrayList<Integer> getSmallist(ArrayList<Integer> biglist)
//创建一个小集合,用来装偶数结果
ArrayList<Integer> smallList = new ArrayList<>();
for (int i = 0;i<biglist.size();i++){
int num = biglist.get(i);
if(num %2==0){
smallList.add(num);
}
}
return smallList;
}

Java学习:集合的使用与数组的区别的更多相关文章

  1. Java学习笔记之---方法和数组

    Java学习笔记之---方法与数组 (一)方法 (1)什么是方法? 方法是解决一类问题的步骤的有序组合 方法包含于类或对象中 方法在程序中被创建,在其他地方被引用 (2)方法的优点 使程序变得更简短而 ...

  2. Java基础知识强化之集合框架笔记01:集合的由来与数组的区别

    1. 集合的由来: 我们学习的是面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,我们就必须把这多个对象进行存储.而要想存储多个对象,就不能是一个基本的变量,而应该 ...

  3. Java学习-集合(转)

    在编写java程序中,我们最常用的除了八种基本数据类型,String对象外还有一个集合类,在我们的的程序中到处充斥着集合类的身影!java中集合大家族的成员实在是太丰富了,有常用的ArrayList. ...

  4. Java学习之基本数据类型和引用数据类型区别

    JAVA中分为基本数据类型和引用数据类型区别一.基本数据类型: byte:Java中最小的数据类型,在内存中占8位(bit),即1个字节,取值范围-128~127,默认值0 short:短整型,在内存 ...

  5. Java学习----集合框架总结

    集合框架总结: Collection接口: Set接口: HashSet//对象必须实现hashCode方法,元素没有顺序呢,效率比LinkedHashSet高 LinkedHashSet//是Has ...

  6. java学习——集合框架(Collection,List,Set)

    集合类的由来: 对象用于封装特有数据,对象多了需要存储,如果对象的个数不确定,就使用集合容器进行存储. 集合特点:1,用于存储对象的容器.2,集合的长度是可变的.3,集合中不可以存储基本数据类型值. ...

  7. Java学习——集合框架【4】

    一.集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个层次. 实 ...

  8. [Java学习]集合

    一. Collection与Map继承结构图 Collection继承结构图 实现Collection接口的类只能存储引用类型!所以set.add(10)会有自动装箱的过程,把int 转成 Integ ...

  9. Java学习小结(1)-数组的创建与传参

    (一)数组的创建 数组的创建包括两部分:数组的申明与分配内存空间. int score[]=null; //申明一维数组 score=new int[3]; //分配长度为3的空间 数组的申明还有另外 ...

随机推荐

  1. Linux发展史与安装-Linux从入门到精通第一天(非原创)

    文章大纲 一.Linux发展史二.Linux系统的安装三.Linux系统的文件四.学习资料下载五.参考文章   一.Linux发展史 1. Linux前身-Unix 1968年 Multics项目MI ...

  2. MySQL Install--CentOS 7配置MySQL服务和开启启动

    创建MySQL服务 编辑文件: vim /usr/lib/systemd/system/mysql.service 录入下面内容: PS: 注意修改ExecStart脚本 [Unit]Descript ...

  3. 题解:洛谷P1891 疯狂LCM

    原题链接 题目描述 描述: 众所周知,czmppppp是数学大神犇.一天,他给众蒟蒻们出了一道数论题,蒟蒻们都惊呆了... 给定正整数N,求LCM(1,N)+LCM(2,N)+...+LCM(N,N) ...

  4. centos7运维记录文档

    问题一:故障记录时间2019年4月4日,查看系统日志报错如下: tail -f /var/log/messages Apr 4 16:29:16 localhost kernel: tracker-e ...

  5. 《浅谈我眼中的express、koa和koa2》好文留存+笔记

    原文 :三英战豪强,思绪走四方.浅谈我眼中的express.koa和koa2 一.回调大坑怎么解决呢? 1.es5可以利用一下第三方库,例如 async 库, 2.或者单纯使用 connect中间件  ...

  6. AtCoder Grand Contest 038题解

    好久没更了 写点东西吧= = A 01Matrix 简单构造 左上角和右下角染成1其他染成0即可 #include<bits/stdc++.h> #define ll long long ...

  7. 海康威视摄像头+OpenCV+VS2017 图像处理小结(二)

    海康威视摄像头+OpenCV+VS2017 图像处理小结(二) https://blog.csdn.net/o_ha_yo_yepeng/article/details/79825648 目录 一.海 ...

  8. hadoop exit code 退出码含义

    原文传送门:http://www.2cto.com/database/201308/236519.html "OS error code 1: Operation not permitted ...

  9. 有关OutputDebugString的一点儿事实

    我最近花了一些时间分析OutputDebugString方法.在我的另一个实验中,我需要一个仅依赖于本机API的OutputDebugString版本.在实现它的过程中,我发现了一些关于OutputD ...

  10. 归并排序 MergeSort

    今天第一次看懂了严奶奶的代码( ̄▽ ̄)~*,然后按照厌奶那的思路进行了一波coding,稍加调试后即可跑起来. 学习链接:排序七 归并排序.图解排序算法(四)之归并排序 merge函数:将两个有序序列 ...