Java 数组ArrayList常用语法详解

恶补基础,记录一下数组ArrayList的常用语法

1.导入

import java.util.ArrayList;

2.定义数组list

ArrayList<类名> list = new ArrayList<类名>(); 不能是基本类型,必须是类

3.获取集合大小

size()

4.存入数据

add(Object object);从下标0开始加入

add(int idx,Object object);将object插入索引为idx的位置,idx<=list.size();

存进不同的对象要单个new,不能通过改变值后加入数组。(涉及到内存)

5.删除

remove(int idx);删除索引为idx的元素,返回该元素,可以用变量去接收,也可不接收

6.清空

clear(); 清空数组

7.替换

set(int idx,Object object); 把object元素和原本索引为idx的元素替换

8.获取指定位置元素

Object get(int idx);

9.判空

bool isEmpty(); 一般不用,size()可以用于判空

10.判断是否有某元素

bool contains(Object object); 基本不用,可以通过查找元素的索引来解决

11.查找元素的索引

int indexOf(Object object); 如果元素存在,则返回索引,否则返回-1,通过是不是-1判断元素在不在数组里

12..对数组list排序

导入Collections类;

import java.util.Collections;

(1)默认自然排序,从小到大

Collections.sort(list); //不可以new出Collections的对象,直接用

(2)自定义排序

导入Comparator类;

import java.util.Comparator;

创建对象的时候需要实现抽象方法compare(),实现自定义排序

package my_acm;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;//自定义排序
//import java.lang.Integer;//lang包中的类不用导也能直接用
public class MyTest4 {
  public static void main(String [] args) {
    ArrayList<Point> list1 = new ArrayList<Point>();
    ArrayList<Integer> list2 = new ArrayList<Integer>();
    //ArrayList<int> list3 = new ArrayList<int>();//报错,基本数据类型不能
    Comparator<Point> comparator = new Comparator<Point>() {
      public int compare(Point p1,Point p2) {
        if(p1.id!=p2.id)
          return p1.id-p2.id;
        else
        {
          if(p1.age!=p2.age)
            return p1.age-p2.age;
          else
            return 0;//不像C++,这里的if-else需要匹配
        }
      }
    };
    Point p1 = new Point();
    p1.id=11;p1.age=21;
    list1.add(p1);
    Point p2 = new Point();
    p2.id=9;p2.age=44;
    list1.add(p2);
    Point p3 = new Point();
    p3.id=2;p3.age=68;
    list1.add(p3);

    /** 修改变量的值在加到数组里是不可行的,(
    p3.id=14;p3.age=23;
    list1.add(p3);
    */
    for(int i=0;i<list1.size();i++) {
      System.out.println( "i="+i+" id="+list1.get(i).id+" age="+list1.get(i).age);
    }
    Collections.sort(list1,comparator);
    System.out.println("按id排序后");

    for(int i=0;i<list1.size();i++) {
      Point x = new Point();
      x=list1.get(i);
      System.out.println( "i="+i+" id="+x.id+" age="+x.age );
    }
  }
}
class Point{
  int id;
  int age;
}

输出结果:

i=0 id=11 age=21
i=1 id=9 age=44
i=2 id=2 age=68

按id排序后

i=0 id=2 age=68
i=1 id=9 age=44
i=2 id=11 age=21

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

相关文章

ArrayList简介:ArrayList 的底层是数组队列,相当于动态数组。与 Java 中的数组相比,它的容量能动态增...
一、进程与线程 进程:是代码在数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位。 线程...
本文为博客园作者所写:&#160;一寸HUI,个人博客地址:https://www.cnblogs.com/zsql/ 简单的一个类...
#############java面向对象详解#############1、面向对象基本概念2、类与对象3、类和对象的定义格式4、...
一、什么是异常? 异常就是有异于常态,和正常情况不一样,有错误出错。在java中,阻止当前方法或作用域...
Collection接口 Collection接口 Collection接口 Collection是最基本的集合接口,一个Collection代表一组...