进程和线程

进程:
    1、多任务:
         单核CPU是怎么执行多任务的呢?

            操作系统轮流让各个任务交替执行,任务1执行0.01秒,切换到任务2, 任务2执行0.01秒,再切换到任务3,执行0.01秒……这样反复执行下去。表 面上看,每个任务都是交替执行的,但是,由于CPU的执行速度实在是太快了 ,我们感觉就像所有任务都在同时执行一样。

            真正的并行执行多任务只能在多核CPU上实现,但是,由于任务数量远远 多于CPU的核心数量,所以,操作系统也会自动把很多任务轮流调度到每个核 心上执行。

            需要的算法:时间片轮转、优先级调度、调度算法


    2、进程:正在运行的代码,就成为进程

          程序:编写完毕的代码,在没有运行的时候,称之为程序


线程:
    1、线程的概念:在运行的进程中会有一个主线程,控制程序的运行。
    2、单线程:只有一个主线程,负责完成所有的任务。
    3、多线程:一个进程中有多个线程,一起完成任务。

    4、线程的注意点:
        1.使用多线程并发的操作,花费时间要短很多;
        2.创建好的线程,需要调用start()方法来启动;
        3.主线程会等待所有的子线程结束后才结束;
        4.查看线程数量:threading.enumerate() 返回当前进程中的所有线程;
        5.多线程程序的执行顺序是不确定的;
        6.当线程的run()方法结束时该线程完成;
        7.无法控制线程调度程序,但可以通过别的方式来影响线程调度的方式;
        8.每个线程一定会有一个名字,尽管上面的例子中没有指定线程对象的name,但是python会自动为线程指定一个名字;
        9.没有给定target参数,对这个对象调用start()方法时,就将执行对象中的run()方法

   5.线程的几种状态:


进程 VS 线程

功能:进程,能够完成多任务,比如 在一台电脑上能够同时运行多个QQ
            线程,能够完成多任务,比如 一个QQ中的多个聊天窗口

定义:进程:是系统进行资源分配和调度的一个独立单位
            线程:是进程的一个实体,是CPU调度和分配的基本单位。
                        它是比进程更小的能独立运行的基本单位.
                        线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源.

区别:1.一个程序至少有一个进程,一个进程至少有线程;
            2.线程的划分尺度小于进程(资源比进程少),使得多线程程序的并发性高;
            3.进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率
            4.线程不能独立执行,必须依赖于进程
      
优缺点:
    线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源的管理和保护;而进程正相反。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值