【Java|多线程与高并发】 使用Thread 类创建线程的5种方法&&如何查看程序中的线程

简介: 多线程编程主要是为了更好地解决并发编程这个问题,因为创建销毁调度一个进程开销比较大(消耗资源多和速度慢),进程之所以开销比较大,主要是在"资源的分配和回收上"而线程也被称为"轻量级进程",因此在解决并发编程这个问题上,线程的创建销毁调度的更快一些.

前言


在这里主要补充说明一些问题,方便更好地理解下面的内容:

1.关于多线程存在有什么意义以及多线程存在有什么好处?

多线程编程主要是为了更好地解决并发编程这个问题,因为创建销毁调度一个进程开销比较大(消耗资源多和速度慢),进程之所以开销比较大,主要是在"资源的分配和回收上"

而线程也被称为"轻量级进程",因此在解决并发编程这个问题上,线程的创建销毁调度的更快一些.

2.线程和进程的关系

一个进程可以有一个线程,也可以有多个线程,但是不能没有线程

在启动线程时,只有第一个线程的开销比较大,后面的开销就很小了

在不支持线程的操作系统中,进程既是资源分配的基本单位,也是调度的基本单位;在拥有线程的操作系统中,线程是调度的基本单位,而进程是资源分配的基本单位。

系统级线程的切换需要内核的支持,用户级线程的切换不需要内核的支持。同一进程中的线程共享同一物理内存空间。

3.增加线程的数量,能否提高执行速度

增加线程的数量不一定能提高速度,因为CPU核心数是有限的,如果创建线程太多,不小的开销主要在调度上浪费了

4.其它的一些知识点

线程就是独立的执行路径

main()线程也称为主线程,为系统的入口,执行整个程序,由JVM进行创建

程序运行时,即使没有手动创建线程,后台也会有多个线程,如:主线程,gc线程

在一个进程中,线程是抢占式执行,各个线程的执行顺序是不确定的

Java多线程中,最核心的类就是Thread类,而使用Thread类不需要导入任何类型的包,因为它是在java.lang包下,默认是导入的 线程主要是为了更好地解决并发编程的问题


线程创建


线程的创建有5种方法,下面为大家一一介绍这些创建线程的方法


1.继承Thread类重写run()方法


//创建线程 方法1:继承Thread 重写run方法

class MyThread extends Thread{

   @Override

   public void run() {

       while(true){

           System.out.println("run方法在执行");

       }

   }

}

public class ThreadDemo1 {

   public static void main(String[] args) {

       Thread thread = new MyThread();

       thread.start();//这里要注意

       while(true){

           System.out.println("main方法在执行");

       }

   }

}

11111.png

在创建好thread这个实例对象之后,调用的方法是start方法,而不是run方法,调用start方法是为了创建一个线程,由这个新的线程去调用thread.run方法,在run方法执行完毕后,创建的这个新的线程就自动销毁了,如果直接调用thread方法,是不会有新的线程的

程序执行流程图区别如下:

11112.png对于上述代码来说,如果只是调用thread.run()方法,那么程序只会一直打印"run方法在执行",不可能会打印"main()方法在执行"


如何查看程序中的线程?


为了更好地看到线程,Java也为我们提供了方法,我们可以使用jdk中自带的工具jconsole来查看当前进程中的所有线程

在查看线程时要运行你想要查看程序的main方法

11114.png11115.png11116.png11117.png11118.png11119.png111120.png


2.实现Runnable接口


实现Runnable接口,要重写的方法也是run()方法

//Runnable 描述一个"要执行的任务"

class MyRunnable implements Runnable{

   @Override

   public void run() {

       System.out.println("hello Thread");

   }

}

public class TreadDemo2 {

   public static void main(String[] args) {

       Runnable runnable = new MyRunnable();//描述了一个任务

       Thread thread = new Thread(runnable);//把任务交给线程来执行

       thread.start();

   }

}

这样的写法最大的好处就是解耦合,目的是为了将任务和线程之间分开


3.使用匿名内部类,继承Thread


public class ThreadDemo3 {

   public static void main(String[] args) {

       Thread thread = new Thread(){

           @Override

           public void run() {

               System.out.println("hello thread");

           }

       };

       thread.start();

   }

}

这里new Thread() 是创建了一个Thread的子类,没有名字,所以是匿名,并让thread指向这个子类对象


4.使用匿名内部类,实现Runnable


public class ThreadDemo4 {

   public static void main(String[] args) {

       Thread thread = new Thread(new Runnable() {

           @Override

           public void run() {

               System.out.println("hello thread");

           }

       });//注意()

       thread.start();

   }

}

这个写法是创建了一个子类,实现了Runnable接口,同时创建了类的实例,并传给Thread的构造方法


5.使用Lambda表达式,创建线程(重要)


这种创建线程的方法最简单,在平时使用的时候,使用Lambda表达式创建线程是最常用的,所以这种线程的创建方式要务必掌握!!!

public class ThreadDemo5 {

   public static void main(String[] args) {

      Thread thread = new Thread(()->{

          System.out.println("hello thread");

      });

      thread.start();

   }

}


Thread 的常见构造方法


Thread 的常见构造方法常见的构造方法有四种=

构造方法 说明

Thread() 创建线程对象

Thread(Runnable target) 使用 Runnable 对象创建线程对象

Thread(String name) 创建线程对象,并命名

Thread(Runnable target, String name) 使用 Runnable 对象创建线程对象,并命名

这里着重说一下第三种和第四种构造方法, 这两种构造方法可以给线程命名.给线程命名的最大好处就是当程序中创建了很多的线程,而程序中地某个线程中出现问题,可以更好地进行调试,更快地找到问题所在.


总结


掌握线程创建的方法,特别是用Lambda表达式创建线程的方法(最简单也最常用)

掌握start()和run()方法之间的区别

相关文章
|
3天前
|
NoSQL Redis
单线程传奇Redis,为何引入多线程?
Redis 4.0 引入多线程支持,主要用于后台对象删除、处理阻塞命令和网络 I/O 等操作,以提高并发性和性能。尽管如此,Redis 仍保留单线程执行模型处理客户端请求,确保高效性和简单性。多线程仅用于优化后台任务,如异步删除过期对象和分担读写操作,从而提升整体性能。
12 1
|
20小时前
|
Java 程序员 调度
【JavaEE】线程创建和终止,Thread类方法,变量捕获(7000字长文)
创建线程的五种方式,Thread常见方法(守护进程.setDaemon() ,isAlive),start和run方法的区别,如何提前终止一个线程,标志位,isinterrupted,变量捕获
|
20小时前
|
安全 Java API
【JavaEE】多线程编程引入——认识Thread类
Thread类,Thread中的run方法,在编程中怎么调度多线程
|
29天前
|
Java C# Python
线程等待(Thread Sleep)
线程等待是多线程编程中的一种同步机制,通过暂停当前线程的执行,让出CPU时间给其他线程。常用于需要程序暂停或等待其他线程完成操作的场景。不同语言中实现方式各异,如Java的`Thread.sleep(1000)`、C#的`Thread.Sleep(1000)`和Python的`time.sleep(1)`。使用时需注意避免死锁,并考虑其对程序响应性的影响。
|
1月前
|
安全 Java
线程安全的艺术:确保并发程序的正确性
在多线程环境中,确保线程安全是编程中的一个核心挑战。线程安全问题可能导致数据不一致、程序崩溃甚至安全漏洞。本文将分享如何确保线程安全,探讨不同的技术策略和最佳实践。
41 6
|
2月前
|
Java 开发者
如何通过易语言多线程提升程序响应速度?
如何通过易语言多线程提升程序响应速度?
|
1月前
|
数据采集 Java Python
爬取小说资源的Python实践:从单线程到多线程的效率飞跃
本文介绍了一种使用Python从笔趣阁网站爬取小说内容的方法,并通过引入多线程技术大幅提高了下载效率。文章首先概述了环境准备,包括所需安装的库,然后详细描述了爬虫程序的设计与实现过程,包括发送HTTP请求、解析HTML文档、提取章节链接及多线程下载等步骤。最后,强调了性能优化的重要性,并提醒读者遵守相关法律法规。
66 0
|
7月前
|
算法 Java 数据处理
Java程序性能优化研究
Java程序性能优化研究
74 0
|
7月前
|
缓存 监控 算法
Java程序性能优化策略与实践
在当今软件开发领域,Java作为一种广泛应用的编程语言,其程序性能优化显得尤为重要。本文将介绍一些Java程序性能优化的策略和实践,帮助开发者提高代码执行效率、减少资源消耗,并优化用户体验。通过深入探讨各种优化技术和工具,读者将能够更好地理解和运用这些策略,有效提升Java应用程序的性能。
55 1
|
监控 算法 Java
限时!字节Java程序性能优化宝典开源,原来这才叫性能优化
让你的Java程序更快、更稳定 程序的性能受代码质量的直接影响。那么该如何让代码在级别上提升系统性能呢? 其实性能提升永远没有捷径,需要 分析、优化、实验、监控 ,需要一点点积累和深入。随着你对项目和性能优化理解不断深入,会发现提升性能的手段变得越来越丰富,性能数据自然也会跟着上去。 一个优秀的程序员,不仅要会编写程序,更要会编写高质量的程序感受Java开发中的大智慧,让你的Java程序更优美。那么今天LZ挖出一份有关Java程序性能优化的文档,可以让你的Java程序更快、更稳定,主要是涵盖了一些Java程序的优化方法和技巧:
69 1