1. 线程时在内核中实现的,纤程是在用户模式下实现(即windows不负责对前程进行处理).
将线程->纤程:PVOID ConvertThreadToFiber(PVOID pvParam);
函数功能:这个函数会为纤程的执行上下文分配大约200字节的内存.上下文的组成如下:
● 一个用户自定义值(他被初始化为传给ConvertThreadToFiber的pvParam参数的 值
● 结构化异常处理链的头
● 纤程栈的顶部和底部的内存地址(相当于线程栈).
● 某些CPU寄存器.其中包括栈指针,指令指针以及其他寄存器
ConcertThreadToFiber实际返回的是上下文的地址.
另外除非我们打算创建了更多的纤程,并让它们在同一线程中运行.否则没有理由将一个线程转换为纤程.
创建纤程:
PVOID CreateFiber(
DWORD dwStackSize,//栈的大小
PFIBER_START_ROUTINE pfnStartAddress,
PVOID pvParam);
PVOID CreateFiberEx(
SIZE_T dwStackCommitSize,//初始化需要调拨的物理内存
SIZE_T dwStackReserveSize//指定数量的虚拟内存
DWORD dwFlags,//标志位.如果想将浮点状态包含到纤程上下文中,可设为 //FIBER_FLAG_FLOAT_SWITCH标志
PFIBER_START_ROUTINE pStartAddress,
PVOID pvParam);
pfnStartAddress的原型如下:
VOID WINAPI FiberFunc(PVOID pvParam);
如果纤程返回,那么该线程以及为它创建所有纤程都将立即被销毁.CreateFiber(ex)会调用分配一个新的纤程执行上下文结构并对其进行初始化.也正是因为这样,CreateFiber(Ex)创建的新的纤程不会立即执行.同时,同一时刻只能执行一个纤程.为了让新的纤程执行我们应该调用SwitchToFiber
VOID SwitchToFiber(PVOID pvFiberExecutionContext);//参数为创建时返回的地址
它的运行过程如下:
◆ 将一些CPU寄存器目前的值,其中包含指令指针寄存器和栈指针寄存器,保存到当前正在运行的纤程的执行上下文中.
◆ 从即将运行的纤程的执行上下文中,将先前保存的寄存器的值载入到CPU寄存器中.这些寄存器中包括栈指针寄存器,这样当线程继续执行的时候,会使用新前程的栈
◆ 将新前程的执行上下文与线程关联起来,让线程运行指定的纤程.
◆ 将线程指令指针设为先前保存的指令指针.这样线程(纤程)就会从上次执行的地方开始继续往下执行.
销毁纤程:VOID DeleteFiber( PVOID pvFIberExecutionContext);
如果传入的纤程地址当前正好与线程相关联,那么该函数会在内部调用ExitThread.从而使得线程以及为他创建的纤程都将结束.
获取当前正在运行的纤程的执行上下文的地址调用GetCurrentFiber:
PVOID GetCurrentFiber();
另一个函数是: PVOID GetFiberData();