Java教程

Java进程与线程

本文主要是介绍Java进程与线程,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

Java多线程

提示:这里不过多讲述线程的概念,如果想去了解可以参考下面的网址:https://www.runoob.com/java/java-multithreading.html

提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • Java多线程
  • 前言
  • 一、什么是进程?
    • 概念:
    • 多进程的意义:
  • 二、什么是线程?
    • 概念:
    • 多线程的意义:
  • 三、多进程VS多线程


前言

这里简单的介绍了进程与线程的概念

提示:以下是本篇文章正文内容,下面案例可供参考

一、什么是进程?

概念:

  • 当前的操作系统都是多任务OS
  • 每个独立执行的任务就是一个进程
  • OS将时间划分为多个时间片(时间很短)
  • **每个时间片内将CPU分配给某个任务,时间片结束,CPU将自动回收,再分配给另外任务。**从外部看,所有任务同时在执行。但是在CPU上任务是按照串行依次运行(单核CPU)。如果是多核,多个进程任务可以并行。但是单个核上,多线程只能串行执行。

多进程的意义:

  • 可以同时运行多个任务
  • 程序因IO堵塞时,可以释放CPU,让CPU为其他程序服务
  • 当系统有多个CPU时,可以为多个程序同时服务

(1)我们的CPU不再提高频率,而是提高核数。
(2)2005年Herb Suttter的文章The free lunch is over,指出多核和并行程序才是提高程序性能的唯一办法。

二、什么是线程?

概念:

  • 一个程序可以包括多个子任务,可串/并行
  • 每个子任务可以称为一个线程
  • 如果一个子任务阻塞,程序可以将CPU调度到别的程序(进程)去。这样,提高本程序所获得CPU时间和利用率。

多线程的意义:

  • 多线程的存在,不是提高程序的执行速度。其实是为了提高应用程序的使用率。
  • 程序的执行其实都是在抢这个资源,而其中的某一个进程如果执行路径比较多,就会有更高的几率抢到CPU的执行权。
  • 线程的执行是有随机性的。

三、多进程VS多线程

  • 线程共享数据
  • 线程通讯更高效
  • 线程更轻量级,更容易切换
  • 多个线程更容易管理
这篇关于Java进程与线程的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!