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
- 你需要通过循环迭代来访问列表中的某些元素。
- 需要频繁的在列表开头、中间、末尾等位置进行添加和删除元素操作。