Thread类常用方法、List


一、Thread类常用方法

  • public static Thread currentThread()
    返回对当前正在执行的线程对象的引用。
  • public String getName()
    返回该线程的名称。
  • public int getPriority()
    返回线程的优先级。
  • public void interrupt()
    中断线程。
    -public static boolean interrupted()
    测试当前线程是否已经中断。
  • public boolean isAlive()
    测试线程是否处于活动状态。
  • public void join()
    等待加入的线程终止。
  • public void run()
    如果该线程是使用独立的 Runnable 运行对象构造的,则调用该 Runnable 对象的 run 方法;否则,该方法不执行任何操作并返回。
  • public void setName(String name)
    改变线程名称,使之与参数 name 相同。
  • public void setPriority(int newPriority)
    更改线程的优先级。
  • public static void sleep(long millis)
    在指定的毫秒数内让当前正在执行的线程休眠(暂停执行),此操作受到系统计时器和调度程序精度和准确性的影响。
  • public void start()
    使该线程开始执行;Java 虚拟机调用该线程的 run 方法。
  • public static void yield()
    暂停当前正在执行的线程对象,并执行其他线程。

二、List

1.ArrayList

ArrayList 类是一个可以动态修改的数组,与普通数组的区别就是它有自动扩容机制,没有大小的限制,我们可以添加或删除元素。ArrayList 继承了 AbstractList ,并实现了 List 接口。

ArrayList构造
  • ArrayList()
    构造一个初始容量为 10 的空列表。
  • ArrayList(Collection<? extends E> c)
    构造一个包含指定 collection 的元素的列表,这些元素是按照该 collection 的迭代器返回它们的顺序排列的。
  • ArrayList(int initialCapacity)
    构造一个具有指定初始容量的空列表。
ArrayList常用方法

在这里插入图片描述
在这里插入图片描述

遍历ArrayList的方式
//1.for循环
        for (int i = 0; i <personArrayList.size(); i++) {
            System.out.println(personArrayList.get(i));
        }
//2.增强for
        for (Person p:
             personArrayList) {
            System.out.println(p);
        }
//3.迭代器
        Iterator<Person> iterator = personArrayList.iterator();
        while (iterator.hasNext()){
            Person p = iterator.next();
            System.out.println(p);
        }

2.LinkedList

LinkedList构造
  • LinkedList()
    构造一个空列表。
  • LinkedList(Collection<? extends E> c)
    构造一个包含指定 collection 中的元素的列表,这些元素按其 collection 的迭代器返回的顺序排列。
LinkedList常用方法

在这里插入图片描述

在这里插入图片描述

遍历LinkedList的方式
for (int i = 0; i < linkedList.size(); i++) {
            System.out.println(linkedList.get(i));
        }
Iterator<NewsContent> iterator = linkedList.iterator();
        while (iterator.hasNext()){
            NewsContent news = iterator.next();
            System.out.println(news);
        }
for (NewsContent news:
             linkedList) {
            System.out.println(news);
        }
        }

三、ArrayList和LinkedList的区别和使用时机

大致区别:

ArrayList是实现了基于动态数组的数据结构,LinkedList是基于双向链表结构。
对于随机访问的get和set方法,ArrayList要优于LinkedList
对于新增和删除操作add和remove,LinkedList比较占优势

链表:

单链表(单向链表):由数据域(Data)和结点域(Node)组成,原理的实现是通过Node结点区的头指针head实现的,每个结点都有一个指针,每个节点指针都指向自身结点的下一个结点,最后一个结点的head指向为null,如果需要查找链表中的某一个结点,则需要从头开始进行遍历。

双链表(双向链表):双向链表多了一个指向尾指针(tail),双链表的每个结点都有一个头指针head和尾指针tail,双链表相比单链表更容易操作,双链表结点的首结点的head指向为null,tail指向下一个节点的tail;尾结点的head指向前一个结点的head,tail 指向为null,是双向的关系;
双向链表除开头节点和最后一个节点外每个节点中储存有两个指针,这连个指针分别指向前一个节点的地址和后一个节点的地址,通过两个节点能够寻找到前后其他的节点。

使用时机:
以下情况使用 ArrayList:

  • 频繁访问列表中的某一个元素。
  • 只需要在列表末尾进行添加和删除元素操作。

以下情况使用 LinkedList

  • 你需要通过循环迭代来访问列表中的某些元素。
  • 需要频繁的在列表开头、中间、末尾等位置进行添加和删除元素操作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值