当前位置: 首页 > 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.lryc.cn/news/578850.html

相关文章:

  • Hadoop集群启动 (ZooKeeper、HDFS、YARN、Hbase)
  • 【网络】Linux 内核优化实战 - net.core.netdev_budget_usecs
  • VSCode-Copilot的系统提示词
  • mac mini m4安装node.js@16以下版本方法
  • Linux下MinIO分布式安装部署
  • REST API设计与Swagger:构建高效、易用的Web服务
  • 如何设置电脑定时休眠?操作指南详解
  • STM32 使用 TinyUSB
  • 【leetcode算法300】:哈希板块
  • 【RTSP从零实践】6、实现最简单的同时传输H264、AAC的RTSP服务器
  • SpringCloud系列(46)--SpringCloud Bus实现动态刷新全局广播
  • 免费版安全性缩水?ToDesk、TeamViewer、向日葵、网易UU远程访问隐私防护测评
  • 2025 年网络钓鱼威胁“狂飙”:如何筑牢防线?
  • 【记录】基于 C++ 和 Winsock 的简单 TCP 通信实现
  • 【Java面试】讲讲Redis的Cluster的分片机制
  • 企智汇研发项目管理系统:软件企业降本增效的数智化解决方案!
  • 蓝桥杯 滑行
  • 蓝桥杯51单片机设计
  • 深入理解装饰器模式:动态扩展对象功能的灵活设计模式
  • [特殊字符] Excel 提取+图片批量插入 | Python 自动化生成稽查报告 Word 模板
  • 基于Java+SpringBoot的图书管理系统
  • 多云密钥统一管理实战:CKMS对接阿里云/华为云密钥服务
  • 分布式定时任务:Elastic-Job-Lite
  • GC393低功耗双电压比较器:精准、高效的信号处理解决方案
  • Axure版ArcoDesign 组件库-免费版
  • OpenCV CUDA模块设备层-----高效地计算两个uint 类型值的平均值函数vavg2()
  • Centos系统及国产麒麟系统设置自己写的go服务的开机启动项完整教程
  • 开源 | V3.1.1慧知开源重卡运营充电桩平台 - 重卡运营充电桩平台管理解决方案;企业级完整代码 多租户、模拟器、多运营商、多小程序;
  • Chrome 下载文件时总是提示“已阻止不安全的下载”的解决方案
  • DQL-1-基础查询