当前位置: 首页 > news >正文

Javaee 多线程 --进程和线程之间的区别和联系

文章目录

  • 进程和线程
    • 进程
    • 线程
    • 进程和线程的区别
  • 创建线程的五种写法
    • 继承Thread,重写run
    • 实现Runnable(接口),重写run
    • 继承Thread,重写run,但是使用匿名内部类
    • 实现Runnable(接口),重写run,但是使用匿名内部类
    • 使用lambda表达式
  • 请说明Thread类中run和start的区别

在这里插入图片描述

进程和线程

进程

  1. 进程:是正在执行的程序,是资源分配的基本单位,具有独立的地址空间
  2. 操作系统会为其分配CPU和内存

线程

  1. 线程:引入线程是为了解决进程开销大,浪费资源的情景,并且多进程并发效率比较低
  2. 线程是调度执行的基本单位
  3. 线程之间会相互影响,一个线程挂了,会影响到整个进程都异常结束,线程也自然会结束

进程和线程的区别

  1. 进程包含线程,一个进程里面有多个线程或者是一个线程
  2. 进程和线程都是用来实现并发编程场景的,但是线程比进程更轻量和高效
  3. 同一个进程的线程之间共用同一份资源(内存和硬盘),省去了申请资源的开销
  4. 进程和进程之间都是独立存在的,不会相互影响,同一个进程中,线程和线程之间会相互影响(线程安全问题 + 线程出现异常)
  5. 进程是分配资源的基本单位,线程是调度执行的基本单位

创建线程的五种写法

继承Thread,重写run

package Thread;class MyThread extends Thread{public void run(){// 这个是线程的入口方法while(true) {System.out.println("hello Thread!");try {Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}}
}// 创建线程
public class Demo1 {public static void main(String[] args) throws InterruptedException {Thread thread = new MyThread();// 使用start方法可以间接调用run方法// start和 run都时Thread的成员// run 只是线程的入口(描述了线程要做什么事情)// start才是真正调用了系统的API,在系统中创建出了线程,让线程调用 runthread.start();// 从这句开始程序就并发执行,一边执行hello main,一边执行hello Thread// 兵分两路进行执行// 并发 == 并行 + 并发while(true){System.out.println("hello main!");Thread.sleep(1000);}// 先执行main,再执行的是Thread,先执行主线程}
}

实现Runnable(接口),重写run

package Thread;class MyRunable implements Runnable{public void run(){while(true){System.out.println("hello thread!");try {Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}}
}
public class Demo2 {public static void main(String[] args) throws InterruptedException {// 这个接口就是用来实现多态的Runnable myRunable = new MyRunable();Thread thread = new Thread(myRunable);thread.start();while(true){System.out.println("hello main!");Thread.sleep(1000);}}
}

继承Thread,重写run,但是使用匿名内部类

  1. 使用匿名内部类的方式创建出线程
package Thread;public class Demo3 {public static void main(String[] args) {Thread thread = new Thread(){public void run(){while(true){System.out.println("hello Thread!");try {Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}}};thread.start();while(true){System.out.println("hello main!");try {Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}}
}

实现Runnable(接口),重写run,但是使用匿名内部类

package Thread;public class Demo4 {public static void main(String[] args) {// 法一:创建实例Runnable runnable = new Runnable(){public void run(){System.out.println("hello Thread!");try {Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}};// 法二:创建匿名对象Thread thread = new Thread(new Runnable(){public void run(){System.out.println("hello Thread!");try {Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}});// Thread thread = new Thread(runnable);thread.start();while(true){System.out.println("hello main!");try {Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}}
}

使用lambda表达式

  1. lambda表达式相当于是匿名内部类的替换写法
package Thread;public class Demo5 {public static void main(String[] args) {Thread thread = new Thread(()->{while(true){System.out.println("hello Thread!");try {Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}});thread.start();while(true){System.out.println("hello main!");try {Thread.sleep(1000);} catch (InterruptedException e) {throw new RuntimeException(e);}}}
}

请说明Thread类中run和start的区别

  1. 从方法的区别,及运行结果的区别分别说明
    1. start方法可以用来启动一个新的线程,run方法只是一个普通的方法,在主线程中执行
    2.start方法只能调用一次,run方法可以调用多次
    3.调用start方法会执行新的线程,新线程和主线程并发执行,run方法只是线程的入口,start方法调用了系统API,start方法创建出了线程,让线程再调用run方法
    4.run方法和主线程同步执行,start方法启动的线程和主线程异步执行
    5.run方法按顺序执行,start方法调用的线程中的代码执行顺序由线程调度器决定,顺序不确定
http://www.dtcms.com/a/264787.html

相关文章:

  • nvm:NodeJs版本管理工具下载安装与使用教程
  • macOS挂载iOS应用沙盒文件夹
  • 飞算 JavaAI 智控引擎:全链路开发自动化新图景
  • 【字节跳动】数据挖掘面试题0003:有一个文件,每一行是一个数字,如何用 MapReduce 进行排序和求每个用户每个页面停留时间
  • 橡胶硬度计在不同领域中的应用
  • mybatis考试
  • 无人机一机多控技术的核心要点
  • 亿级物联网MQTT集群:OpenResty深度优化实践
  • Docker for Windows 设置国内镜像源教程
  • 基于spark的航班价格分析预测及可视化
  • v3 中的storeToRefs
  • AWS WebRTC:根据viewer端拉流日志推算视频帧率和音频帧率
  • uniapp实现图片预览,懒加载
  • 数据分类分级系统的建设思路
  • Rust 安装使用教程
  • 【已解决】执行conda init提示No action taken.
  • 客服机器人知识库怎么搭?智能客服机器人3种方案深度对比(含零售落地案例)
  • 部署KVM 虚拟化平台
  • AI驱动,治理升级!数造科技亮相中博会,打造一站式数据开发治理新范式
  • OFA-PT:统一多模态预训练模型的Prompt微调
  • 暴力破解漏洞与命令执行漏洞
  • PHP 命令行工具的常用选项详解
  • 图像二值化方法及 Python OpenCV 实现
  • 深度剖析NumPy核心函数reshape()
  • 香港券商交易系统开发与解决方案全景报告:云原生、跨境协同与高性能架构的创新实践
  • qt-- 学习笔记11(mingw编译,windeployqt生成执行文件exe,同一exe文件不同文件夹结果不同)
  • 分布式定时任务:Elastic-Job-Lite
  • P3842 [TJOI2007] 线段(动态规划)
  • RAC (ReactiveCocoa) 的实现机制与消息传递策略
  • XILINX Kintex 7系列FPGA的架构