线程的基本概念

线程的基本概念

程序

  • 完成特定的任务,用某种语言编写的一组指令的集合
  • 指一段静态的代码

进程

  • 程序的一次执行过程
  • 正在运行的一个程序
  • 动态过程
  • 进程作为资源分配的单位,系统会为每个进程分配不同的内存区域
  • 进程可以细化为多个线程

线程

  • 线程作为调度和执行的最小单位
  • 进程可以进一步细化为线程,一个程序内部执行的一条执行路径
  • 线程作为调度和执行的单位,每个线程拥有独立的运行栈和计数器
  • 多个线程共享同一个进程中的结构:方法区、堆
  • 会存在安全隐患
  • 一个java应用程序,至少有三个线程
    • main()主线程
    • gc()垃圾回收线程
    • 异常处理线程

JVM内存解析

1.png

并行与并发

  • CPU分为单核CPU和多核CPU

并行、并发

  • 并行:多个CPU同时执行多个任务
  • 并发:一个CPU同时执行多个任务

需要创建多线程的情况

  • 程序需要同时执行两个或多个任务
  • 程序需要实现一些需要等待的任务时,如用户输入、文件读写
  • 需要一些后台运行的程序时
posted @ 2020-07-20 10:48  南煎丸子  阅读(77)  评论(0)    收藏  举报