• 多线程


    多线程概述
    进程:
    正在运行的程序,是系统进行资源分配和调用的独立单位。
    每一个进程都有它自己的内存空间和系统资源。
    线程:
    是进程中的单个顺序控制流,是一条执行路径
    一个进程如果只有一条执行路径,则称为单线程程序。
    一个进程如果有多条执行路径,则称为多线程程序。

    1:要想说线程,首先必须得聊聊进程,因为线程是依赖于进程存在的。
    2:那么,什么是进程呢?通过任务管理器我们就可以看到进程的存在。
    给出一个概念:进程就是正在运行的程序,是系统进行资源分配和调用的独立单位。每一个进程都有它自己的内存空间和系统资源。
    3:多进程有什么意义呢?
    单进程计算机只能做一件事情。而我们现在的计算机都可以一边玩游戏(游戏进程),一边听音乐(音乐进程),所以我们常见的操作系统都是多进程操作系统。比如:Windows,Mac和Linux等,能在同一个时间段内执行多个任务。
    对于单核计算机来讲,游戏进程和音乐进程是同时运行的吗?不是。
    因为CPU在某个时间点上只能做一件事情,计算机是在游戏进程和音乐进程间做着频繁切换,且切换速度很快,所以,我们感觉游戏和音乐在同时进行,其实并不是同时执行的
    多进程的作用不是提高执行速度,而是提高CPU的使用率。

    4:那么什么又是线程呢?
    在一个进程内部又可以执行多个任务,而这每一个任务我们就可以看成是一个线程。线程是程序中单个顺序的控制流,是程序使用CPU的基本单位。

    5:多线程有什么意义呢?
    多线程的作用不是提高执行速度,而是为了提高应用程序的使用率。
    而多线程却给了我们一个错觉:让我们认为多个线程是并发执行的。其实不是。
    因为多个线程共享同一个进程的资源(堆内存和方法区),但是栈内存是独立的,一个线程一个栈。所以他们仍然是在抢CPU的资源执行。一个时间点上只有能有一个线程执行。而且谁抢到,这个不一定,所以,造成了线程运行的随机性。

    6:那么什么又是并发呢?
    大家注意两个词汇的区别:并行和并发。
    前者是逻辑上同时发生,指在某一个时间内同时运行多个程序。
    后者是物理上同时发生,指在某一个时间点同时运行多个程序。
    那么,我们能不能实现真正意义上的并发呢,是可以的,多个CPU就可以实现,不过你得知道如何调度和控制它们。

    7:那么,我们来举例说说什么是进程,什么是线程。
    扫雷游戏,迅雷下载等。

    Java程序运行原理
    java 命令会启动 java 虚拟机,启动 JVM,等于启动了一个应用程序,也就是启动了一个进程。该进程会自动启动一个 “主线程” ,然后主线程去调用某个类的 main 方法。所以 main方法运行在主线程中。在此之前的所有程序都是单线程的。
    思考:
    jvm虚拟机的启动是单线程的还是多线程的?

    答:JVM启动至少启动了垃圾回收线程和主线程,所以是多线程的。

     

  • 相关阅读:
    windows快速安装redis
    Tensorflow教程(3)什么是张量?什么是数据流图?
    Tensorflow教程(2)Tensorflow的常用函数介绍
    Tensorflow教程(1)Tensorflow的下载和安装
    oracle获取当天时间的最开始的时间和最结尾的时间
    kindeditor在线文本编辑器过滤HTML的方法
    用PHP抓取淘宝商品的用户晒单评论+图片实例
    用PHP抓取百度贴吧邮箱数据
    微信公众号天气查询接口实例
    【Python】自动化升级所有pip安装的包
  • 原文地址:https://www.cnblogs.com/zhaoyanhaoBlog/p/9181907.html
Copyright © 2020-2023  润新知