Java多线程的使用
基本概念
程序(program):数据结构+算法,是为了某种特定的任务,用某种语言编写的一组指令的集合,即指一段静态的代码,静态对象.
进程(process):是程序的一次执行过程,或是正在运行的一个程序.
线程(thread):进程可进一步细分为线程,是一个程序内部的一条执行路径,一个进程可同时拥有多个线程,则为多线程.线程作为调度和执行的单位,每个线程拥有独立的运行栈和程序计数器.
Thread中的常用方法
-
start():启动当前线程;调用当前线程的run().
-
run():通常需要重写Thread类中的此方法,将创建的线程要执行的操作声明在此方法中.
-
currentThread(): 静态方法,返回执行当前代码的线程.
-
getName(): 获取当前线程的名字.
-
setName(): 设置当前线程的名字.
-
yield(): 释放当前cpu的执行权
-
join(): 在线程a中调用线程b的join(),此时线程a就进入阻塞状态,直到线程b完全执行完以后,线程a才结束阻塞状态.
-
stop(): 已过时,当执行此方法时,强制结束当前线程.
-
sleep(): 让当前线程"睡眠"指定的millitime毫秒.在指定的millitime毫秒时间内,当前线程是阻塞状态.
-
isAlive(): 判断当前线程是否存活.
线程的优先级
-
MAX_PRIORITY: 10
-
MIN_PRIORITY: 1
-
NORM_PRIORITY: 5
getPriority(): 获取线程的优先级
setPriority(int p): 设置线程的优先级
高优先级的线程要抢占低优先级线程Cpu的执行权.但是只是从概率上讲,高优先级的线程高概率下被执行.并不意味着只有当高优先级的线程执行完以后,低优先级的线程才执行.
创建方式一、继承Thread类
继承Thread类并重写run()方法,通过调用start()方法启动线程
class Thread_1 extends Thread
{
@Override
public void run() {
for(int i = 0;i < 100; i++)
{
System.out.println(Thread.currentThread().getName());
}
}
}
class Thread_2 extends Thread
{
@Override
public void run() {
for(int i = 0;i < 100; i++)
{
System.out.println(Thread.currentThread().getName());
}
}
}
public class ThreadDemo {
public static void main(String[] args) {
Thread_1 t1 = new Thread_1();
Thread_2 t2 = new Thread_2();
t1.start();
t2.start();
}
}
或者通过创建Thread类的匿名内部类方式调用start()方法.
public class ThreadDemo {
public static void main(String[] args) {
new Thread()
{
@Override
public void run() {
for(int i = 0;i<100;++i)
{
System.out.println(Thread.currentThread().getName());
}
}
}.start();
new Thread()
{
@Override
public void run() {
for(int i = 0;i<100;++i)
{
System.out.println(Thread.currentThread().getName());
}
}
}.start();
}
}
创建方式二、实现Runnable接口
-
创建一个实现了Runnable接口的类
-
实现类去实现Runnable中的抽象方法: run()
-
创建实现类的对象
-
将此对象作为参数传递到Thread类的构造器中,创建Thread类的对象
-
通过Thread类的对象调用start()
class MThread implements Runnable
{
@Override
public void run() {
for(int i = 0;i<100;i++)
{
System.out.println(i);
}
}
}
public class ThreadTest1 {
public static void main(String[] args) {
MThread mt = new MThread();
Thread t1 = new Thread(mt);
t1.start();
}
}
还有两种创建方式,通过实现Callable接口以及线程池的使用.