19/365 java 多线程

文章介绍了程序作为指令和数据的集合,进程作为程序的动态执行实例,以及线程作为CPU调度的基本单位。在多线程环境中,即使单CPU也会通过快速切换模拟多核执行。线程间有独立的内存空间,但需处理并发控制问题,且创建线程会有额外开销。示例展示了通过继承Thread类创建并启动线程的方法。
摘要由CSDN通过智能技术生成

1. 基础概念

程序:指令集和数据的集合。(静态)

进程:对程序的一次执行。(动态)

          对同一个程序,执行两次,那就是两个进程。

          进程是系统资源分配的基本单位

线程:一个进程中包含多个(>=1)线程。

          线程是CPU调度和执行的基本单位。

多线程:真正的多线程是多个CPU同时执行多个线程(多核)

              在只有一个CPU时,是通过快速切换不同的线程,来模拟多核。

              实际上,在具体的一刻,只能执行一个线程。

2.概述

  • 线程之间是相互独立的,有自己的内存工作空间
  • main()为系统的主线程,是执行的入口
  • 并发控制:解决多个线程竞争同一份资源的问题
  • 线程会带来额外的开销,例如并发控制开销,CPU调度时间

3.创建线程

  • 继承Thread类
  • 实现Runnable接口
  • 实现Callable接口

4.继承Thread类来创建线程

步骤:

  • 定义一个类继承Thread类
  • 重写run()方法
public class D7 extends Thread{
    @Override
    public void run() {
        int n = 100;
        for(int i=0;i<n;i++){
            System.out.println("This is thread " + i);
        }
    }
}

  • 创建该类,调用start()方法
public static void main(String[] args) {
        D7 d7 = new D7();
        d7.start();

        int n = 100;
        for(int i=0;i<n;i++){
            System.out.println("This is main Thread " + i);
        }

    }

执行结果:

可以开出确实是交替执行了两个线程

如下图所示,调用该类的run(),就是正常的执行流程,调用start()便会多线程执行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值