多线程基础

相关概念

  • 程序:
    • 为完成特定任务,用某种语言编写的一组指令的集合。即指一段静态的代码,静态对象。
  • 进程:
    • 程序的一次执行过程,或是正在内存中运行的应用程序。
    • 每个进程都有一个独立的内存空间,系统运行一个程序即是一个进程从创建、运行到消亡的过程
    • 程序是静态的,进程是动态的
    • 进程作为操作系统调度和分配资源的最小单位,系统在运行时会为每个进程分配不同的内存区域
    • 现代的操作系统,大多是支持多进程的,支持同时运行多个程序。
  • 线程:
    • 进程可进一步细化为线程,是程序内部的一条执行路径。一个进程中至少有一个线程。
    • 线程是CPU调度和执行的最小单位

多线程创建

继承Thread类

class MyThread extends Thread {
    public void run() {
        System.out.println("MyThread running");
    }
}

public class Main {
    public static void main(String[] args) {
        MyThread thread = new MyThread();
        thread.start();
    }
}

实现Runnable接口

class MyRunnable implements Runnable {
    public void run() {
        System.out.println("MyRunnable running");
    }
}

public class Main {
    public static void main(String[] args) {
        MyRunnable myRunnable = new MyRunnable();
        Thread thread = new Thread(myRunnable);
        thread.start();
    }
}

Thread类的常用方法和生命周期

Thread类的常用方法:

  • start():
    • 用于启动线程,当调用start()方法时,线程会执行run()方法中定义的任务。
  • run():
    • 包含线程的执行代码,需要在自定义的Thread类中重写这个方法来定义线程的行为。
  • sleep(long millis):
    • 让当前线程休眠指定的时间(以毫秒为单位)。
  • join():
    • 等待该线程终止。
  • interrupt():
    • 中断线程。
  • isAlive():
    • 判断线程是否还存活。
  • setName(String name):
    • 设置线程的名称。

线程的生命周期:

  • New(新建状态):
    • 当线程对象被创建但还没有调用start()方法时,处于新建状态。
  • Runnable(可运行状态):
    • 调用start()方法后,线程进入可运行状态,等待获取CPU时间片。
  • Running(运行状态):
    • 线程获取CPU时间片后开始执行run()方法中的任务。
  • Blocked(阻塞状态):
    • 线程被阻塞,等待某个条件的解除,如等待输入输出、等待获取锁等。
  • Waiting(等待状态):
    • 线程进入等待状态,等待其他线程的通知或中断。
  • Timed Waiting(计时等待状态):
    • 线程在一定时间内等待,超时后会自动唤醒。
  • Terminated(终止状态):
    • 线程执行完run()方法中的任务或者出现异常,进入终止状态。

线程同步

同步方法:

  • 可以使用 synchronized 修饰方法,使得每次只有一个线程可以访问该方法。
public synchronized void synchronizedMethod() {
    // 同步代码块
}

同步代码块:

  • 也可以使用 synchronized 关键字来同步代码块,指定一个对象作为锁。
public void synchronizedBlock() {
    synchronized (this) {
        // 需要同步的代码块
    }
}

使用 Lock 接口实现线程同步

  • 除了使用 synchronized 关键字外,还可以使用 java.util.concurrent.locks.Lock 接口来实现线程同步
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class ThreadSyncExample {
    private Lock lock = new ReentrantLock();

    public void doSomething() {
        lock.lock();
        try {
            // 需要同步的代码块
        } finally {
            lock.unlock();
        }
    }
}

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值