操作系统之用户级线程

进程是既切换指令,同时也切换映射表(进程访问地址从映射表中获得),映射表对应的是内存,内存是程序执行所需的资源,需要用到的资源都存放在内存中

进程=资源(映射表)+指令执行序列

如 mov 100 ,在每个进程中都可以写,但是每个进程对应有自己的映射表,映射到物理内存中就不一样了,从而实现地址分离

线程是只切换指令,不切换映射表,将资源和指令执行分开,只是切换了PC指针和部分寄存器,映射表没有切换

所以说,线程既保留了并发的优点,又避免了进程切换的代价

多个指令序列同时出发(creat函数),交替执行,用户级线程,要想交替执行,是主动调用函数,调用函数时,就是从一个函数切换到另一个函数(用yield函数切出去,交替执行)

用yield完成切换

TCB和栈相互配合,栈中的底端地址放在esp中,完成栈的切换。

切换的时候只要切换栈就可以,PC指针已经被压入栈中,执行yield时,会自动弹栈。

两个线程:有两个TCB(thread control block),两个栈,切换的PC在栈中

一个栈,一个TCB与栈关联,栈里放着返回的地址

ThreadCreat 核心:做出上面这三样东西,栈,TCB,TCB和栈关联

void ThreadCreat (A)

{

TCB tcb=malloc(); //申请一段内存作为tcb

stack=malloc(); //申请一段内存作为栈

*stack=A; //在栈里填上程序的初始地址

tcb.esp=stack; //栈和tcb关联

}

yield:用户级线程,完全是用户栈,没有进入到内核

核心级线程(schedule):TCB在内核中,内核级线程并发性好一些

原文地址:https://www.cnblogs.com/ymd12103410/p/9857228.html

时间: 2024-08-09 12:30:30

操作系统之用户级线程的相关文章

操作系统: 用户级线程和内核级线程

1 .内核级线程:切换由内核控制,当线程进行切换的时候,由用户态转化为内核态.切换完毕要从内核态返回用户态:可以很好的利用smp,即利用多核cpu.windows线程就是这样的. 2. 用户级线程内核的切换由用户态程序自己控制内核切换,不需要内核干涉,少了进出内核态的消耗,但不能很好的利用多核Cpu,目前Linux pthread大体是这么做的. 线程的实现可以分为两类:用户级线程(User-Level Thread)和内核线线程(Kernel-Level Thread),后者又称为内核支持的线

操作系统--用户级线程和内核级线程

在多线程操作系统中,各个系统的实现方式并不相同.在有的系统中实现了用户级线程,有的系统中实现了内核级线程 1.内核级线程: (1)线程的创建.撤销和切换等,都需要内核直接实现,即内核了解每一个作为可调度实体的线程. (2)这些线程可以在全系统内进行资源的竞争. (3)内核空间内为每一个内核支持线程设置了一个线程控制块(TCB),内核根据该控制块,感知线程的存在,并进行控制. 在一定程度上类似于进程,只是创建.调度的开销要比进程小.有的统计是1:10 2.用户级线程: (1)用户级线程仅存在于用户

操作系统--内核支持线程和用户级线程

内核支持线程(Kernel Supported threads)KST OS中的所有进程(用户和内核)都是依靠内核完成的.KST也是如此,它的创建,阻塞,撤销,切换都是在内核空间实现. 优点: 内核可以同时调度同一进程中的多个线程并行执行 一个线程被阻塞了,内核可以调度随便一个进程中的其他线程占用处理器 采用多线程技术,可以提高西永的执行速度 用户级线程ULT 在用户空间实现,它的创建,阻塞,撤销,切换都无需内核的支持-->用户级线程与内核无关.所以内核完全不知道用户级线程的存在,也就不能看到用

[No000039]操作系统Operating Systems用户级线程User Threads

多进程是操作系统的基本图像 是否可以资源不动而切换指令序列? 进程 = 资源 + 指令执行序列 线程: 保留了并发的优点,避免了进程切换代价 实质就是映射表不变而PC 指针变 多个执行序列+ 一个地址空间是否实用? 一个网页浏览器 一个线程用来从服务器接收数据 一个线程用来显示文本 一个线程用来处理图片( 如解压缩) 一个线程用来显示图片 这些线程要共享资源吗? 接收数据放在100 处,显示时要读.. 所有的文本.图片都显示在一个屏幕上 开始实现这个浏览器… void WebExplorer()

用户级线程和内核级线程的区别

转载于http://col1.blog.163.com/blog/static/1909775192012719114033352/ 1 .内核级线程:切换由内核控制,当线程进行切换的时候,由用户态转化为内核态.切换完毕要从内核态返回用户态:可以很好的利用smp,即利用多核cpu.windows线程就是这样的. 2. 用户级线程内核的切换由用户态程序自己控制内核切换,不需要内核干涉,少了进出内核态的消耗,但不能很好的利用多核Cpu,目前Linux pthread大体是这么做的. 线程的实现可以分

多线程 用户级线程和内核级线程 from C++多核高级编程

转 http://book.51cto.com/art/201006/206946.htm 6.1.1 用户级线程和内核级线程 2010-06-21 20:37 齐宁/董泽惠 译 清华大学出版社 字号:T | T <C++多核高级编程>第6章多线程,本章将介绍:什么是线程; 用于线程管理的pthread API;线程调度及优先级;线程竞争范围;扩展thread_object以封装线程属性功能.本节为大家介绍用户级线程和内核级线程. AD: 6.1.1  用户级线程和内核级线程 线程有3种实现模

内核级线程与用户级线程

这两天在写这篇blog的时候,顺带复习操作系统的资料,遇到了一个之前没有弄明白的问题,就是关于内核级线程与用户级线程.在查阅了一些资料之后,发表一下我个人简介. 线程已经在许多系统中实现,到那时各个操作系统实现方式不完全相同. 比如在有的系统中,特倍是一些数据库管理系统如IBM的infomix系统,所实现的用户级线程(UserLevel Threads ,ULT):而另一些系统如(Mac os的前身Macintosh和OS/2操作系统)所实现的是内核支持线程 ( Kernel Supported

线程的实现方式之内核支持线程和用户级线程

线程是OS进行独立调试.执行的基本单位,进程是系统进行资源分配的基本单位,一个进程可以包含若干个线程.无论是系统进程还是用户进程,进程的创建.撤消.以及要求系统设备完成的IO操作,都是利用系统调用而进入内核,再由内核中相应处理程序予以完成.进程的切换同样是在内核的支持下实现的.即不论什么样的进程,它们都是在OS内核的支持下运行的,是与内核紧密相关的. 1. 线程的分类 线程根据其实现方式不同又可分为内核支持线程KST(Kernel Supported Threads).用户级线程ULT(User

线程的3种实现方式--内核级线程, 用户级线程和混合型线程

之前降解过内核线程.轻量级进程.用户线程三种线程概念解惑(线程≠轻量级进程), 但是一直对其中提到的线程的实现模型比较迷惑, 这次就花了点时间怎么学习了一下子 1 线程的3种实现方式 在传统的操作系统中,拥有资源和独立调度的基本单位都是进程.在引入线程的操作系统中,线程是独立调度的基本单位,进程是资源拥有的基本单位.在同一进程中,线程的切换不会引起进程切换.在不同进程中进行线程切换,如从一个进程内的线程切换到另一个进程中的线程时,会引起进程切换 根据操作系统内核是否对线程可感知,可以把线程分为内