线程和进程之我见

  l  概念(什么线程和进程?)

    ²  进程

    进程是操作系统结构的基础;是一次程序的执行;是一个程序及其数据在处理机上顺序执行时所发生的活动。

    进程是表示资源分配的基本单位,又是调度运行的基本单位。例如,用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括各种表格、内存空间、磁盘空间、I/O设备等。然后,把该进程放人进程的就绪队列。进程调度程序选中它,为它分配CPU以及其它有关资源,该进程才真正运行。所以,进程是系统中的并发执行的单位。

    进程存在三个状态,具体如下图:


    就绪状态:进程已经得到运行所需的资源,只等待CPU的调度就可运行。

    运行状态:集成已经得到运行所需的资源,并且得到了CPU的调度。

    等待状态:不具备运行条件、等待时机的状态。由于进程等待某种条件(如I/O操作或进程同步),在条件满足之前无法继续执行。该事件发生前即使把处理机分配给该进程,也无法运行。即等待也为阻塞状态。

 

    ²  线程

   线程是进程中执行运算的最小单位,亦即执行处理机调度的基本单位。如果把进程理解为在逻辑上操作系统所完成的任务,那么线程表示完成该任务的许多可能的子任务之一。

线程可以在处理器上独立调度执行,这样,在多处理器环境下就允许几个线程各自在单独处理器上进行。操作系统提供线程就是为了方便而有效地实现这种并发性。

      Ø  多线程原理的理解

      多线程下载的原理是这样的:通常服务器同时与多个用户连接,用户之间共享带宽。如果N个用户的优先级都相同,那么每个用户连接到该服务器上的实际带宽就是服务器带宽的N分之一。可以想象,如果用户数目较多,则每个用户只能占有可怜的一点带宽,下载将会是个漫长的过程。   如果你通过多个线程同时与服务器连接,那么你就可以榨取到较高的带宽了。例如原来有10个用户都通过单一线程与服务器相连,服务器的总带宽假设为56Kbps,则每个用户(每个线程)分到的带宽是5.6Kbps,即0.7K字节/秒。如果你同时打开两个线程与服务器连接,那么共有11个线程与服务器连接,而你获得的带宽将是56/11*2=10.2Kbps,约1.27K字节/秒,将近原来的两倍。你同时打开的线程越多,你所获取的带宽就越大,当然,这种情况下占用的机器资源也越多。

  l  线程与进程的关系和区别

现在的操作系统是多任务操作系统。多线程是实现多任务的一种方式。

    进程是程序的一个动态执行过程,是指一个内存中运行的应用程序,每个进程都有自己独立的一块内存空间,一个进程中可以启动多个线程。比如在Windows系统中,一个运行的exe就是一个进程。线程是指进程中的一个执行流程,一个进程中可以运行多个线程。比如java.exe进程中可以运行很多线程。线程总是属于某个进程,进程中的多个线程共享进程的内存。“同时”执行是人的感觉,在线程之间实际上轮换执行。

²  线程和进程的关系

    (1)一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。线程是操作系统可识别的最小执行和调度单位。

    (2)资源分配给进程,同一进程的所有线程共享该进程的所有资源。 同一进程中的多个线程共享代码段(代码和常量),数据段(全局变量和静态变量),扩展段(堆存储)。但是每个线程拥有自己的栈段,栈段又叫运行时段,用来存放所有局部变量和临时变量。

    (3)处理机分给线程,即真正在处理机上运行的是线程。

    (4)线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。

    简而言之,一般你运行一个应用程序,就生成了一个进程, 这个进程拥有自己的内存空间,

    这个进程还可以内部生成多个线程, 这些线程之间共用一个进程的内存空存空间,所以线程之间共享内存是很容易做到的,多线程协作比多进程协作快一些,而且安全。

    我们来生活化的举例,比如你想要做一盘烧茄子,那么炒这盘菜就是一个进程,那个锅就是你要占用的系统资源。之后的那些材料比如说淀粉、茄子、酱油、醋等等就是一个个处于即将成为线程的状态。

    下面该炒这盘菜了,那么往锅里放各种材料就是一个一个的线程,多个线程是可以一起的,比如可以同时放酱油和醋等等,当然你也可以同时开启两个进程,只要你有足够的资源,这里说的人力,如果你能同时兼顾两件事情,那么就好了,你可以同时即炒菜又煮粥,这个随资源而定。

    我们可以看出,菜以及酱油还有醋等等是属于这个进程的,也是就是炒菜进程的开启的。也就是说线程是属于进程的,一个进程可以拥有多个线程。

    这样一说,是不是清楚点呢,这是我自己的理解,不足之处还望大家多多指教。


评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值