首页 > 编程语言 >Java多线程简介

Java多线程简介

时间:2022-11-14 12:55:14浏览次数:41  
标签:Java Thread 简介 start 线程 new 多线程 public

一、线程简介

  1. Process进程与Thread线程
    程序是指令和数据的有序集合,本身没有任何运行的含义,为静态概念。
    进程是执行程序的一次执行过程,为动态概念。是系统资源分配的单位。
    通常在一个进程中包含若干个线程,当然一个进程至少包含一个线程,不然毫无意义。线程是CPU调度和执行的单位。
    注意:很多多线程都是模拟出来的,真正的多线程是指多个CPU,即多核。
  2. main()称之为主线程,为系统的入口,用于执行整个程序。

二、线程实现(重点)

1. Java多线程实现原理

image
image

2. 线程实现的三种方式

Thread class ---->继承Thread类 (重点)
Runnable 接口---->实现(Runnable)接口 (重点)
Callable 接口---->实现(Callable)接口 (了解)

3. 小结

3.1 继承Thread类

- 子类继承Thread类具备多线程能力
- 启动对象:子类对象.start()
- **不建议使用,避免OOP单继承局限性**

3.2 实现Runnable接口

- 实现接口Runnable具有多线程能力
- 启动线程:传入目标对象+Thread对象.start()
- **推荐使用,避免单继承的局限性,灵活方便,方便同一对象被多个线程使用**。
package Thread;

//创建线程方法1 :继承Thread类,重写run()方法,调用start方法开启线程

//线程开启不一定立即执行,由CPU调度执行
public class TestThread extends Thread{
    @Override
    public void run() {
        //run方法线程体
        for (int i = 0; i < 20; i++) {
            System.out.println("我在看代码"+i);
        }
    }

    public static void main(String[] args) {
        //main线程,主线程

        //创建一个线程对象
        TestThread testThread = new TestThread();

        //调用start方法,开启线程
        testThread.start();

        for (int i = 0; i < 20; i++) {
            System.out.println("我在学习多线程"+i);
        }
    }
}

package Thread;

//创建线程方式2,实现runnable接口,重写run,执行线程需要丢入runnable接口实现类,调用start方法
public class TestRunnable {

    public static void main(String[] args) {
        //创建runnable接口的实现类对象
        //一份资源
        MyRunnable myRunnable = new MyRunnable();

//        //封装线程对象
//        Thread t01 = new Thread(myRunnable, "线程01");
//        Thread t02 = new Thread(myRunnable, "线程02");
//        Thread t03 = new Thread(myRunnable, "线程03");
//
//        //开启线程
//        t01.start();
//        t02.start();
//        t03.start();

        //多个代理
        new Thread(myRunnable,"线程01").start();
        new Thread(myRunnable,"线程02").start();
        new Thread(myRunnable,"线程03").start();

        //通过匿名内部类方式创建类
        new Thread(new Runnable() {
            @Override
            public void run() {
                for (int i = 0; i < 20; i++) {
                    System.out.println(Thread.currentThread().getName()+i);
                }
            }
        },"线程04-").start();
    }
}


class MyRunnable implements Runnable{
    @Override
    public void run(){
        for (int i = 0; i < 50; i++) {
            System.out.println(Thread.currentThread().getName()+"-"+i);
        }
    }
    
}

三、线程状态

四、线程同步(重点)

五、线程通信问题

六、高级主题

标签:Java,Thread,简介,start,线程,new,多线程,public
From: https://www.cnblogs.com/quliangshyang/p/16888689.html

相关文章

  • Java的安装及开发环境
    卸载JDK删除Java的安装目录删除Java_HOME删除path下关于Java的目录Java-version安装JDK找到JDK官网,同意协议并下载http://www.oracle.com/technetwork......
  • Web前端开发技术课程大作业,期末考试HTML+CSS+JavaScript电竞游戏介绍网站
    ......
  • RabbitMq简介
    RabbitMq简介RabbitMQ是一个由erlang开发的AMQP(AdvancedMessageQueue高级消息队列协议)的开源实现,由于erlang语言的高并发特性,性能较好,本质是个队列,FIFO先入先出,里面......
  • Java项目精选|Java毕业设计项目源码
    【IT学长】Java项目精选,做毕业设计、课程设计、入门项目实战的伙伴可以参考项目名称:​​《SSM+MySQL+JSP教务管理系统设计与实现(附源码下载地址)》​​使用技术:Java+Sprin......
  • 又一巨头从 Java 迁移到 Kotlin,简直很无语。。
    出品|OSC开源社区(ID:oschina2013)Meta发布了一篇博客表示,正在将其Android应用的Java代码迁移到Kotlin,并分享了这一过程中的一些经验。该公司认为,Kotlin是一种流......
  • NFV简介-华为
    转自:https://info.support.huawei.com/info-finder/encyclopedia/zh/NFV.html1.什么是NFV 网络功能虚拟化(NetworkFunctionsVirtualization,NFV)是一种关于网络架构的概......
  • Java中常用的JSON库,哪个性能更牛?
    前言每次都在网上看到别人说什么某某库性能是如何如何的好,碾压其他的库。但是百闻不如一见,只有自己亲手测试过的才是最值得相信的,本篇通过JMH来测试一下Java中几种常见的JSO......
  • 月薪10k,20k,40k的Java工程师,差别到底在哪?
    最近某乎又有了一个热议话题:月薪10k,20k,40k的Java工程师,差别到底在哪?出现这种现象,表面上是每个人所在的岗位、公司、级别不同,本质的原因其实是因为大家的能力不同。不管什么......
  • 【NET微服务】微服务简介
    一、什么是微服务微服务是一种架构风格,它要求我们在开发一个应用的时候,这个应用必须构建成一系列小服务的组合;可以通过http的方式进行互通。二、单体应用架构所谓单体应......
  • Java 云原生微服务框架 Quarkus 入门实践
    1.概述1.1定义Quarkus定位要做超声速、亚原子的Java框架,使用最好标准为OpenJDKHotSpot和GraalVM量身定制的KubernetesNativeJava栈;从一开始就是针对Kubernetes设计的云......