C#中多线程自我折腾之一-进程,线程的基本概念
2012-10-01 22:22
302 查看
首先要明确的是,计算机科学的发展,离不开对人类行为的模拟。多线程的意义,打个比方,就是比如幼年时期,我们看电视时,可能就忘记咀嚼嘴巴里的食物;后来,我们可以一边看电视,一边吃饭,甚至还能边吃饭边用手指掏鼻孔。
从操作系统的角度来讲,进程是一项独立运行的程序任务的实例以及该任务所包含的程序、内存和系统资源;一个进程有相应的虚拟地址空间,以确保与其他进程之间的执行和访问的独立性,提高应用程序的健壮性。同时,操作系统的内核代码和数据对进程是不可见的;线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针、程序计数器等),但代码区是共享的,即不同的线程可以执行同样的函数。图一展示了CPU/进程和线程之间工作交互的小样例。
在Windows中,开辟一个进程的开销通常在几秒中左右,这个开销已经非常昂贵。开辟进程时,必须给进程分配相应的内存,同时还得初始化内存;同时,进程需要执行的程序的exe和相关的DLL文件需要从磁盘上加载等。与进程相比,在Windows中创建一个线程的开销则少很多。因为各线程间可以共享资源和程序。但是,由此而来也会带来额外的开销:
1.线程越多,占用的内存越多;
2.线程也需要CPU花费时间周期去管理和调度;
3.大量线程存在,严重考验调度算法的健壮性和复杂性,也影响线程的平均等待时间。
因此,需要记住:线程并不廉价,需要根据实际需要开辟线程。
从操作系统的角度来讲,进程是一项独立运行的程序任务的实例以及该任务所包含的程序、内存和系统资源;一个进程有相应的虚拟地址空间,以确保与其他进程之间的执行和访问的独立性,提高应用程序的健壮性。同时,操作系统的内核代码和数据对进程是不可见的;线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针、程序计数器等),但代码区是共享的,即不同的线程可以执行同样的函数。图一展示了CPU/进程和线程之间工作交互的小样例。
在Windows中,开辟一个进程的开销通常在几秒中左右,这个开销已经非常昂贵。开辟进程时,必须给进程分配相应的内存,同时还得初始化内存;同时,进程需要执行的程序的exe和相关的DLL文件需要从磁盘上加载等。与进程相比,在Windows中创建一个线程的开销则少很多。因为各线程间可以共享资源和程序。但是,由此而来也会带来额外的开销:
1.线程越多,占用的内存越多;
2.线程也需要CPU花费时间周期去管理和调度;
3.大量线程存在,严重考验调度算法的健壮性和复杂性,也影响线程的平均等待时间。
因此,需要记住:线程并不廉价,需要根据实际需要开辟线程。
相关文章推荐
- 多线程之基础篇01:进程与线程的基本概念
- 多线程(一) 进程和线程的基本概念
- 多线程系列一 进程和线程基本概念
- 进程,线程,多线程概念
- 进程、线程、协程基本概念理解
- c# 多线程学习笔记 (一)基本概念
- java 孙鑫 第五课 Java 的多线程,程序、进程和线程的概念
- 深入浅出进程与线程的基本概念
- 深入浅出进程与线程的基本概念
- Java线程和多线程(一)——线程的基本概念
- 线程 进程 多线程的概念
- 【windows编程--进程与线程】多线程的概念
- 深入浅出进程与线程的基本概念
- POSIX多线程—线程基本概念
- java 多线程(3) 线程的基本概念 / 创建和启动 / run() / start()
- 线程的基本概念及线程与进程的关系
- 【多线程】线程的基本概念
- 进程 (process)和 线程 (thread)是操作系统的基本概念
- 线程进程Java多线程(一)、理解进程与多线程的概念及关系
- [疯狂Java]多线程:进程和线程的概念