6.1、线程概念及与进程之间的关系

1、什么是线程

	LWP:轻量级的进程,本质仍是进程(在Linux环境下)。
	线程是进程中的一个实体,是CPU调度和分配的最小单位。
	进程:独立地址空间,拥有PCB
	线程:也有PCB,但没有独立的地址空间(共享)
	区别:在于是否共享地址空间。	独居(进程);合租(线程)。
	Linux下:	线程:最小的执行单位
	 					进程:最小分配资源单位,可看成是只有一个线程的进程。

2、Linux内核线程实现原理

	1. 轻量级进程,也有PCB,创建线程使用的底层函数和进程一样,都是clone
	2. 从内核里看进程和线程是一样的,都有各自不同的PCB,但是PCB中指向内存资源的三级页表是相同的
	3. 进程可以蜕变成线程(当一个进程中起了一个线程则进程自动退化成多线程)
	4. 线程可看做寄存器和栈的集合
	5. 在linux下,线程最是小的执行单位;进程是最小的分配资源单位
		察看LWP号:ps –Lf pid 查看指定线程的lwp号。
	6. Linux内核是不区分进程和线程的。只在用户层面上进行区分。

3、线程与进程间关系

	对于进程来说,相同的地址(同一个虚拟地址)在不同的进程中,反复使用而不冲突。原因是他们虽虚拟址一样,但页目	录、页表、物理页面各不相同。相同的虚拟址,映射到不同的物理页面内存单元,最终访问不同的物理页面。
	但!线程不同!两个线程具有各自独立的PCB,但共享同一个页目录,也就共享同一个页表和物理页面。所以两个PCB共享一个地址空间。
实际上,无论是创建进程的fork,还是创建线程的pthread_create,底层实现都是调用同一个内核函数clone。
如果复制对方的地址空间,那么就产出一个“进程”;如果共享对方的地址空间,就产生一个“线程”。
因此:Linux内核是不区分进程和线程的。只在用户层面上进行区分。所以,线程所有操作函数 pthread_* 是库函数,而非系统调用。

4、线程共享资源及非共享资源

		《共享资源》
		1.文件描述符表
		2.每种信号的处理方式
		3.当前工作目录
		4.用户ID和组ID
		5.内存地址空间 (.text/.data/.bss/heap/共享库)
		
		《非共享资源》
		1.线程id
		2.处理器现场和栈指针(内核栈)
		3.独立的栈空间(用户空间栈)
		4.errno变量
		5.信号屏蔽字
		6.调度优先级

5、线程优、缺点

		优点:	1. 提高程序并发性	2. 开销小	3. 数据通信、共享数据方便
		缺点:	1. 库函数,不稳定	2. 调试、编写困难、gdb不支持	3. 对信号支持不好
		优点相对突出,缺点均不是硬伤。Linux下由于实现方法导致进程、线程差别不是很大。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值