zoukankan      html  css  js  c++  java
  • 线程的理解

    1. 单线程和多线程的理解

    单线程如同只雇佣一个服务员的餐厅,他必须做完一件事情之后,才可以做下一件事情.

    多线程如同雇佣多个服务员的餐厅,他们可以同时进行着多件事情.

    1. 进程和线程的区别

    几乎所有操作系统都支持进程的概念,所有运行中的任务都对应一个进程。当一个程序进入内存运行,即变成一个进程。进程是处于运行过程中的程序,并且具有一定独立功能,进程是系统进行资源分配和调度的一个独立单位。

    进程包含三个特性:

    (1)       独立性:进程是系统中独立存在的实体,它拥有自己独立的资源,每一个进程都拥有自己私有的地址空间。在没有经过进程本身允许的情况下,一个用户进程不可以直接访问其他进程的地址空间。

    (2)       动态性:进程和程序的区别在于,程序只是一个静态的指令集合,而进程是一个正在系统中活动的指令集合。在进程中加入了时间的概念。进程具有自己的生命周期和各种不同的状态,这些概念在程序中是不具备的。

    (3)       并发性:多个进程可以在单个处理器上并发执行,多个进程之间不会相互影响。

    多线程扩展了多进程的概念,使得同一个进程可以同时并发处理多个任务。线程也被称为轻量级进程,线程是进程的执行单元。就像进程在操作系统中的地位一样,线程在程序中是独立的、并发的执行流。

    线程可以拥有自己的堆栈、自己的程序计数器和自己的局部变量,但不再拥有系统资源,它与父进程的其他线程共享该进程所拥有的全部资源。

    多线程的优点:

    (1)       进程间不能共享内存,但线程之间共享内存非常容易

    (2)       系统创建进程,需要为进程分配系统资源,但创建线程则代价小得多,因此使用多线程来实现多任务并发比多进程的效率高。

    (3)       Java语言内置多线程功能支持,而不是单纯地作为底层操作系统的调度方式,从而简化了java的多线程编程。

  • 相关阅读:
    线程池
    队列Queue、栈LifoQueue、优先级队列PriorityQueue
    线程的定时器Timer
    线程的条件Condiition
    线程的信号量Semaphore
    死锁的原因及解决办法RLock递归锁
    线程锁Lock
    守护线程daemon
    threding模块的其他用法
    变量的存储方式和生存期
  • 原文地址:https://www.cnblogs.com/zhuhaiying/p/4923815.html
Copyright © 2011-2022 走看看