Java基础--集合解析-ArrayList
1.ArrayList中添加,获取,删除元素;
2.ArrayList中是否包含某个元素;
3.ArrayList中根据索引将元素数值改变(替换);
4.ArrayList中查看(判断)元素的索引;
5.根据元素索引位置进行的判断;
6.利用ArrayList中索引位置重新生成一个新的ArrayList(截取集合);
7.对比两个ArrayList中的所有元素;
8.判断ArrayList是否为空;
9.返回Iterator集合对象;
10.将集合转换为字符串;
11.将集合转换为数组;
12.集合类型转换;
13.去重复;
完整代码
package com.java.section10; /**
* <p>Title: ArrayListDemo.java</p>
* @author daxiang
* @version 1.0 创建时间:2018年5月8日 下午9:21:22
*/ import java.util.ArrayList;
import java.util.List; public class ArrayListDemo { public static void main(String[] args) { // list中添加,获取,删除元素
List<String> person = new ArrayList<>();
person.add("jackie"); // 索引为0 //.add(e)
person.add("peter"); // 索引为1
person.add("annie"); // 索引为2
person.add("martin"); // 索引为3
person.add("marry"); // 索引为4 person.remove(3); // .remove(index)
person.remove("marry"); // .remove(Object o) String per = "";
per = person.get(1);
System.out.println(per); //// .get(index) for (int i = 0; i < person.size(); i++) {
System.out.println(person.get(i));
} // list总是否包含某个元素
List<String> fruits = new ArrayList<>();
fruits.add("苹果");
fruits.add("香蕉");
fruits.add("桃子");
// for循环遍历list
for (int i = 0; i < fruits.size(); i++) {
System.out.println(fruits.get(i));
}
String appleString = "苹果";
// true or false
System.out.println("fruits中是否包含苹果:" + fruits.contains(appleString)); if (fruits.contains(appleString)) {
System.out.println("我喜欢吃苹果");
} else {
System.out.println("我不开心");
} // list中根据索引将元素数值改变(替换)
String a = "白龙马", b = "沙和尚", c = "八戒", d = "唐僧", e = "悟空";
List<String> people = new ArrayList<>();
people.add(a);
people.add(b);
people.add(c);
people.set(0, d); // .set(index, element) //将d唐僧放到list中索引为0的位置,替换a白龙马
people.add(1, e); // .add(index, element);
//将e悟空放到list中索引为1的位置,原来位置的b沙和尚后移一位 // 增强for循环遍历list
for (String str : people) {
System.out.println(str);
} // list中查看(判断)元素的索引
List<String> names = new ArrayList<>();
names.add("刘备"); // 索引为0
names.add("关羽"); // 索引为1
names.add("张飞"); // 索引为2
names.add("刘备"); // 索引为3
names.add("张飞"); // 索引为4
System.out.println(names.indexOf("刘备"));
System.out.println(names.lastIndexOf("刘备"));
System.out.println(names.indexOf("张飞"));
System.out.println(names.lastIndexOf("张飞")); // 根据元素索引位置进行的判断
if (names.indexOf("刘备") == 0) {
System.out.println("刘备在这里");
} else if (names.lastIndexOf("刘备") == 3) {
System.out.println("刘备在那里");
} else {
System.out.println("刘备到底在哪里?");
} // 利用list中索引位置重新生成一个新的list(截取集合)
List<String> phone = new ArrayList<>();
phone.add("三星"); // 索引为0
phone.add("苹果"); // 索引为1
phone.add("锤子"); // 索引为2
phone.add("华为"); // 索引为3
phone.add("小米"); // 索引为4 // 原list进行遍历
for (String pho : phone) {
System.out.println(pho);
} // 生成新list
phone = phone.subList(1, 4); // .subList(fromIndex, toIndex)
//利用索引1-4的对象重新生成一个list,但是不包含索引为4的元素,4-1=3
for (int i = 0; i < phone.size(); i++) {
// phone.size()
// 该方法得到list中的元素数的和
System.out.println("新的list包含的元素是" + phone.get(i));
} // 对比两个list中的所有元素
// 两个相等对象的equals方法一定为true, 但两个hashcode相等的对象不一定是相等的对象
if (person.equals(fruits)) {
System.out.println("两个list中的所有元素相同");
} else {
System.out.println("两个list中的所有元素不一样");
} if (person.hashCode() == fruits.hashCode()) {
System.out.println("我们相同");
} else {
System.out.println("我们不一样");
} // 判断list是否为空
// 空则返回true,非空则返回false
if (person.isEmpty()) {
System.out.println("空的");
} else {
System.out.println("不是空的");
} // 返回Iterator集合对象
System.out.println("返回Iterator集合对象:" + person.iterator()); // 将集合转换为字符串
String liString = "";
liString = person.toString();
System.out.println("将集合转换为字符串:" + liString); // 将集合转换为数组,默认类型
System.out.println("将集合转换为数组:" + person.toArray()); // 将集合转换为指定类型(友好的处理)
// 1.默认类型
List<Object> listsStrings = new ArrayList<>();
for (int i = 0; i < person.size(); i++) {
listsStrings.add(person.get(i));
}
// 2.指定类型
List<StringBuffer> lst = new ArrayList<>();
for (String string : person) {
lst.add(StringBuffer(string));
} } private static StringBuffer StringBuffer(String string) {
return null;
} }
Java基础--集合解析-ArrayList的更多相关文章
- Java基础-集合框架-ArrayList源码分析
一.JDK中ArrayList是如何实现的 1.先看下ArrayList从上而下的层次图: 说明: 从图中可以看出,ArrayList只是最下层的实现类,集合的规则和扩展都是AbstractList. ...
- Java基础-集合的嵌套
Java基础-集合的嵌套 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.静态导入 静态导入是在JDK1.5后的新特性,可以减少开发的代码量,但是实际用处是很一般,静态导入的标准 ...
- JAVA基础-集合(二)
一.Map整体结构体系 Map是集合的另一大派系,与Collection派系不同的是Map集合是以键值对儿的形式存储在集合的.两个键为映射关系,其中第一个键为主键(主键是唯一的不可重复),第二个键为v ...
- Java基础——集合框架
Java的集合框架是Java中很重要的一环,Java平台提供了一个全新的集合框架.“集合框架”主要由一组用来操作对象的接口组成.不同接口描述一组不同数据类型.Java平台的完整集合框架如下图所示: 上 ...
- Java基础—集合
一.概述 Java中的集合框架主要分为两大派别:Collection 和 Map —— 位于util包下 类的基础关系图如下(图片来自百度) 常用: List——有序可重复 Set——无序不可重复 M ...
- Java基础集合简单总结
集合 Collection单列集合有List 和 Set List集合有: ArrayList集合 特点: 1.存取有序 可以重复 有索引 2.底层是数组实现,查询快,增删慢 ArrayList底层: ...
- java基础---集合(1)
一. 基本概念 集合.数组都是对多个数据进行存储操作的结构,简称Java容器 数组:长度确定,类型确定,对于添加.删除.插入等操作效率不高,元素有序可重复 Java中集合框架顶层框架是:java.ut ...
- C#语言基础——集合(ArrayList集合)
集合及特殊集合 集合的基本信息: System.Collections 命名空间包含接口和类,这些接口和类定义各种对象(如列表.队列.位数组.哈希表和字典)的集合.System.Collections ...
- Java基础——集合源码解析 List List 接口
今天我们来学习集合的第一大体系 List. List 是一个接口,定义了一组元素是有序的.可重复的集合. List 继承自 Collection,较之 Collection,List 还添加了以下操作 ...
随机推荐
- 【数据结构】K-D Tree
K-D Tree 这东西是我入坑 ICPC 不久就听说过的数据结构,但是一直没去学 QAQ,终于在昨天去学了它.还是挺好理解的,而且也有用武之地. 目录 简介 建树过程 性质 操作 例题 简介 K-D ...
- K8s PV and PVC and StorageClass
PVC和PV之间没有依靠ID.名称或者label匹配,而是靠容量和访问模式,PVC的容量和访问模式需要是某个PV的子集才能自动匹配上.注意:PVC和PV是一对一的,也即一个PV被一个PVC自动匹配后, ...
- MySQL开发篇,存储引擎的选择真的很重要吗?
前言 谁说MySQL查询千万级别的数据很拉跨?我今天就要好好的和你拉拉家常,畅谈到深夜,一起过除夕!这篇文章也是年前的最后一篇,希望能带给大家些许收获,不知不觉查找文档和参考实体书籍就写了这么多,自己 ...
- docker简单介绍。
docker是啥? 一.概念? // 和运维有关的工具,和开发没有很大的关系.只需要去调试项目,将项目运行更迅速. 二.作用? 1.只需要关心项目的编写和调试,不需要关心具体的项目需要运行在哪里,并且 ...
- VS Code拓展--Language Support for Java(TM) by Red Hat(1.3.0)
Language Support for Java(TM) by Red Hat(1.3.0) 注意:版本问题,可能会有部分出入 功能目录 设置 java.home 作用: 指定用于启动 Java 语 ...
- SpringBoot的.gitignore文件使用
简介 临时文件,编译的中间文件等不要提交到代码仓库,这时就要设置相应的忽略规则,来忽略这些文件的提交.git提供了一个.gitignore,来自动忽略这些配置文件 配置规则 # 表示此为注释,将被Gi ...
- Maven警告解决:Using platform encoding (UTF-8 actually)
感谢原文作者:Scorpip_cc 原文链接:https://www.jianshu.com/p/9c8c01f6bebc 执行Maven Install打包的时候,提示以下警告信息: [WARNIN ...
- JDK及JRE简介
JDK(Java Development Kit)是Sun Microsystems针对Java开发员的产品.自从Java推出以来,JDK已经成为使用最广泛的Java SDK.JDK 是整个Java的 ...
- 利用纯代码写出一个秒表表盘的方法 —— #DF
@interface ViewController () @property (nonatomic, strong) CALayer *secLayer; // 秒针layer @property ( ...
- 云端iclound使用-陈棚
使用NSmetadataQuery查询文档,增加,删除,编辑 界面设计完成后效果如图: 程序清单:FKDiary.h @interface FKDiary : UIDocument @property ...