Java中对List集合的常用操作详解

目录:

1.list中添加,获取,删除元素;

2.list中是否包含某个元素;

3.list中根据索引将元素数值改变(替换);

4.list中查看(判断)元素的索引;

5.根据元素索引位置进行的判断;

6.利用list中索引位置重新生成一个新的list(截取集合);

7.对比两个list中的所有元素;

8.判断list是否为空;

9.返回Iterator集合对象;

10.将集合转换为字符串;

11.将集合转换为数组;

12.集合类型转换;

备注:内容中代码具有关联性。

1.list中添加,获取,删除元素;

添加方法是:.add(e); 

获取方法是:.get(index);  

删除方法是:.remove(index);

按照索引删除;.remove(Object o);

按照元素内容删除;

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)); //.get(index)
      } 

2.list中是否包含某个元素;

方法:.contains(Object o); 返回true或者false

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("我不开心");
      }

3.list中根据索引将元素数值改变(替换);

注意 .set(index, element); 和 .add(index, element); 的不同;

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);
      }

4.list中查看(判断)元素的索引;  

注意:.indexOf(); 和  lastIndexOf()的不同;

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("张飞"));

 5.根据元素索引位置进行的判断;

if (names.indexOf("刘备")==0) {
  System.out.println("刘备在这里");
}else if (names.lastIndexOf("刘备")==3) {
  System.out.println("刘备在那里");
}else {
  System.out.println("刘备到底在哪里?");
}

6.利用list中索引位置重新生成一个新的list(截取集合);

方法: .subList(fromIndex, toIndex);  .size() ; 该方法得到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));
      }

7.对比两个list中的所有元素;

//两个相等对象的equals方法一定为true, 但两个hashcode相等的对象不一定是相等的对象

//1.<BR>if (person.equals(fruits)) {
  System.out.println("两个list中的所有元素相同");
}else {
  System.out.println("两个list中的所有元素不一样");
}
//2.
if (person.hashCode()==fruits.hashCode()) {
  System.out.println("我们相同");
}else {
  System.out.println("我们不一样");
}

8.判断list是否为空;

  //空则返回true,非空则返回false

if (person.isEmpty()) {
  System.out.println("空的");
}else {
  System.out.println("不是空的");
}

9.返回Iterator集合对象;

System.out.println("返回Iterator集合对象:"+person.iterator());

1+0.将集合转换为字符串;

String liString="";
liString=person.toString();
System.out.println("将集合转换为字符串:"+liString);

11.将集合转换为数组;

System.out.println("将集合转换为数组:"+person.toArray());

12.集合类型转换;

//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));
}

附完整代码:

package MyTest01; 

import java.util.ArrayList;
import java.util.List; 

public class ListTest01 { 

  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)); //.get(index)
      } 

      //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中对List集合的常用操作详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • java ArrayList按照同一属性进行分组

    java ArrayList按照同一属性进行分组 前言: 通常使用SQL查询一批数据的时候,可以利用SQL中的GROUP BY语句对数据进行分组,但是有时候出于对性能的考虑,不会使用GROUP BY,而是先把数据捞出来后,使用代码,在内存中按照某个属性进行分组. 代码 public class SkuVo { private Long skuId; private String productName; private Long brandStoreSn; public SkuVo(Long s

  • 分析Java中ArrayList与LinkedList列表结构的源码

    一.ArrayList源码分析(JDK7) ArrayList内部维护了一个动态的Object数组,ArrayList的动态增删就是对这个对组的动态的增加和删除. 1.ArrayList构造以及初始化 ArrayList实例变量 //ArrayList默认容量 private static final int DEFAULT_CAPACITY = 10; //默认空的Object数组, 用于定义空的ArrayList private static final Object[] EMPTY_ELE

  • Java中List的使用方法简单介绍

    Java中的List就是一种集合对象,将所有的对象集中到一起存储.List里面可以放任意的java对象,也可以直接放值. 使用方法很简单,类似于数组. 使用List之前必须在程序头引入java.util.* import java.util.*; public class list { public static void main(String args[]) { List a=new ArrayList(); a.add(1);//在LIST a中添加1 System.out.println

  • Java List简介_动力节点Java学院整理

    Java中可变数组的原理就是不断的创建新的数组,将原数组加到新的数组中,下文对Java List用法做了详解.  List:元素是有序的(怎么存的就怎么取出来,顺序不会乱),元素可以重复(角标1上有个3,角标2上也可以有个3)因为该集合体系有索引  ArrayList:底层的数据结构使用的是数组结构(数组长度是可变的百分之五十延长)(特点是查询很快,但增删较慢)线程不同步  LinkedList:底层的数据结构是链表结构(特点是查询较慢,增删较快)  Vector:底层是数组数据结构 线

  • 浅谈java中对集合对象list的几种循环访问

    java中对集合对象list的几种循环访问的总结如下  1 经典的for循环 public static void main(String[] args) { List<String> list = new ArrayList(); list.add("123"); list.add("java"); list.add("j2ee"); System.out.println("=========经典的for循环=======

  • 多用多学之Java中的Set,List,Map详解

    很长时间以来一直代码中用的比较多的数据列表主要是List,而且都是ArrayList,感觉有这个玩意就够了.ArrayList是用于实现动态数组的包装工具类,这样写代码的时候就可以拉进拉出,迭代遍历,蛮方便的. 也不知道从什么时候开始慢慢的代码中就经常会出现HashMap和HashSet之类的工具类.应该说HashMap比较多一些,而且还是面试经典题,平时也会多看看.开始用的时候简单理解就是个键值对应表,使用键来找数据比较方便.随后深入了解后发现 这玩意还有点小奥秘,特别是新版本的JDK对Has

  • 由ArrayList来深入理解Java中的fail-fast机制

    1. fail-fast简介 "快速失败"也就是fail-fast,它是Java集合的一种错误检测机制.某个线程在对collection进行迭代时,不允许其他线程对该collection进行结构上的修改. 例如:假设存在两个线程(线程1.线程2),线程1通过Iterator在遍历集合A中的元素,在某个时候线程2修改了集合A的结构(是结构上面的修改,而不是简单的修改集合元素的内容),那么这个时候程序就会抛出 ConcurrentModificationException 异常,从而产生f

  • Java中对List集合的常用操作详解

    目录: 1.list中添加,获取,删除元素: 2.list中是否包含某个元素: 3.list中根据索引将元素数值改变(替换): 4.list中查看(判断)元素的索引: 5.根据元素索引位置进行的判断: 6.利用list中索引位置重新生成一个新的list(截取集合): 7.对比两个list中的所有元素: 8.判断list是否为空: 9.返回Iterator集合对象: 10.将集合转换为字符串: 11.将集合转换为数组: 12.集合类型转换: 备注:内容中代码具有关联性. 1.list中添加,获取,

  • 对django views中 request, response的常用操作详解

    request 获取post请求中的json数据 def hello(request): data = json.loads(request.body) ... json格式还有一些 非表单序列化 的格式,都可以从 request.body 中获取请求体中的数据,对于ajax请求可以使用 request.is_ajax() 来判断 根据请求的信息获取base url(有时候服务的域名比较多,还是需要动态的拼接一下url信息) # url http://wificdn.com:8888/wxpay

  • 基于java中的PO VO DAO BO POJO(详解)

    一.PO:persistant object 持久对象,可以看成是与数据库中的表相映射的ava对象. 最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合PO中应该不包含任何对数据库的操作. 二.VO:value object值对象.通常用于业务层之间的数据传递,和PO一样也是仅仅包含数据而已.但应是抽象出的业务对象可以和表对应也可以不这根据业务的需要 三.DAO:data access object 数据访问对象,此对象用于访问数据库.通常和PO结合使用,DAO中包含了各种

  • Java中map遍历方式的选择问题详解

    1. 阐述 对于Java中Map的遍历方式,很多文章都推荐使用entrySet,认为其比keySet的效率高很多.理由是:entrySet方法一次拿到所有key和value的集合:而keySet拿到的只是key的集合,针对每个key,都要去Map中额外查找一次value,从而降低了总体效率.那么实际情况如何呢? 为了解遍历性能的真实差距,包括在遍历key+value.遍历key.遍历value等不同场景下的差异,我试着进行了一些对比测试. 2. 对比测试 一开始只进行了简单的测试,但结果却表明k

  • Java中遍历ConcurrentHashMap的四种方式详解

    这篇文章主要介绍了Java中遍历ConcurrentHashMap的四种方式详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 方式一:在for-each循环中使用entries来遍历 System.out.println("方式一:在for-each循环中使用entries来遍历");for (Map.Entry<String, String> entry: map.entrySet()) { System.out.pr

  • Java中Validated、Valid 、Validator区别详解

    目录 1. 结论先出 JSR 380 Valid VS Validated 不同点? Validator 2. @Valid和​​​​​​​@Validated 注解 3. 例子 4.使用@Valid嵌套校验 5. 组合使用@Valid和@Validated 进行集合校验 6. 自定义校验 自定义约束注解 工作原理 结论 参考链接: 1. 结论先出 Valid VS Validated 相同点 都可以对方法和参数进行校验 @Valid和@Validated 两种注释都会导致应用标准Bean验证.

  • Java 中 Class Path 和 Package的使用详解

    目录 一. 类路径 (class path) 二. 包 (package) 三. jar 文件 一. 类路径 (class path) 当你满怀着希望安装好了 java, 然后兴冲冲地写了个 hello world,然后编译,运行, 就等着那两个美好的单词出现在眼前, 可是不幸的是, 只看到了 Can't find class HelloWorld 或者 Exception in thread "main" java.lang.NoSuchMethodError : maain.为什么

  • Java中的Collections类的使用示例详解

    Collections的常用方法及其简单使用 代码如下: package Collections; import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.Stack; public class collections { public static void main(String[]args){ int array[]={125,75,56,7}; Li

  • Java中JDBC实现动态查询的实例详解

    一 概述 1.什么是动态查询? 从多个查询条件中随机选择若干个组合成一个DQL语句进行查询,这一过程叫做动态查询. 2.动态查询的难点 可供选择的查询条件多,组合情况多,难以一一列举. 3.最终查询语句的构成 一旦用户向查询条件中输入数据,该查询条件就成为最终条件的一部分. 二 基本原理 1.SQL基本框架 无论查询条件如何,查询字段与数据库是固定不变的,这些固定不变的内容构成SQL语句的基本框架,如 select column... from table. 2.StringBuilder形成D

  • Java中volatile关键字的作用与用法详解

    volatile这个关键字可能很多朋友都听说过,或许也都用过.在Java 5之前,它是一个备受争议的关键字,因为在程序中使用它往往会导致出人意料的结果.在Java 5之后,volatile关键字才得以重获生机. volatile 关键字作用是,使系统中所有线程对该关键字修饰的变量共享可见,可以禁止线程的工作内存对volatile修饰的变量进行缓存. volatile 2个使用场景: 1.可见性:Java提供了volatile关键字来保证可见性. 当一个共享变量被volatile修饰时,它会保证修

随机推荐