成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

纖程與協程的區別

系統
纖程是操作系統級別的實現,而協程是語言級別的實現。纖程被操作系統內核控制,協程對于內核而言不可見。

纖程(Fiber)是 Windows 操作系統提供的概念。那什么是纖程呢?

纖程是一種比線程更輕量級的執行單元,它可以在一個線程中切換執行,不需要操作系統內核的干預。纖程可以用來實現異步任務,避免了創建新線程的開銷。纖程也叫做協程(coroutine),是一種用戶態的多任務機制。

協程與纖程主要的區別點:

  • 纖程是操作系統級別的實現,而協程是語言級別的實現。纖程被操作系統內核控制,協程對于內核而言不可見。
  • 纖程和線程類似,都擁有自己的棧、寄存器現場等資源,但是纖程更輕量級,一個線程可以包含多個纖程。協程也可以有自己的棧(stackful)或者共享棧(stackless),但是寄存器現場由用戶代碼保存和恢復。
  • 纖程之間的切換由用戶控制,需要顯式地調用轉換函數。協程之間的切換也由用戶控制,但是可以通過生成器、異步函數等語法糖來隱式地實現。
  • 纖程只出現在 Windows 上,而協程在很多語言和平臺上都有支持。

一個簡單的纖程程序,創建兩個纖程并在它們之間切換:

#include "pch.h"
#include <iostream>
#include <windows.h>
#include <tchar.h>

#define FIBER_COUNT 2

LPVOID g_lpFiber[FIBER_COUNT] = {};

VOID WINAPI FiberFun(LPVOID pParam) //纖程函數的返回類型為VOID,并不是因為返回值沒有意義,而是因為這個函數不應該返回!
{
    int nFiberIndex = (int)pParam;
    while (true)
    {
        std::cout << "Fiber" << nFiberIndex << std::endl;
        SwitchToFiber(g_lpFiber[1 - nFiberIndex]); //切換到另一個纖程
    }
}

int _tmain(int argc, _TCHAR* argv[])
{
    LPVOID lpMainFiber = ConvertThreadToFiber(NULL); //將當前線程轉換為主纖程
    if (lpMainFiber == NULL)
    {
        std::cout << "ConvertThreadToFiber failed" << std::endl;
        return -1;
    }

    for (int i = 0; i < FIBER_COUNT; i++)
    {
        g_lpFiber[i] = CreateFiber(0, FiberFun, (LPVOID)i); //創建子纖程
        if (g_lpFiber[i] == NULL)
        {
            std::cout << "CreateFiber failed" << std::endl;
            return -1;
        }
    }

    SwitchToFiber(g_lpFiber[0]); //切換到第一個子纖程

    for (int i = 0; i < FIBER_COUNT; i++)
    {
        DeleteFiber(g_lpFiber[i]); //刪除子纖程
    }

    ConvertFiberToThread(); //將主纖程轉換回線程

    return 0;
}

一個使用纖程實現協同程序的例子:

#include <windows.h>
#include <stdio.h>

#define MAX_FIBERS 3

DWORD dwCounter;

void WINAPI MyFunc(LPVOID lpParameter)
{
 DWORD dwIndex;

 dwIndex = *(DWORD *)lpParameter;

 while(TRUE)
 {
  printf("dwCounter=%d,dwIndex=%d\n",dwCounter,dwIndex);
  dwCounter++;
  SwitchToFiber(lpParameter);
 }
}

void main()
{
 LPVOID lpMainAddress;
 LPVOID lpAddress[MAX_FIBERS];
 DWORD dwParameter[MAX_FIBERS];
 int i;

 lpMainAddress=ConvertThreadToFiber(NULL);

 for(i=0;i<MAX_FIBERS;i++)
 {
  dwParameter[i]=i+1;
  lpAddress[i]=CreateFiber(0,(LPFIBER_START_ROUTINE)MyFunc,&dwParameter[i]);
 }

 for(i=0;i<10;i++)
  SwitchToFibers(lpAddress[i%MAX_FIBERS]);

 for(i=0;i<MAX_FIBERS;i++)
  DeleteFibers(lpAddress[i]);

 printf("end\n");
}
  • 協程是一種在應用層模擬的線程,它可以在不同的執行點之間切換,而不需要操作系統的干預。
  • 協程可以提高程序的性能和并發能力,同時也簡化了異步編程的復雜度。
  • 協程是一種輕量級的并發技術,它可以在單個線程內執行多個任務,從而實現高效的并發操作。與線程相比,協程的優勢在于它可以避免線程切換的開銷,減少資源占用,同時也更易于編程。

盡管協程的概念早于線程,但協程的實現并不是所有操作系統原生支持的。目前,很多編程語言都是通過自己的運行時環境來模擬協程,利用線程技術來實現協程的調度。這些語言中,像 golang 這樣的語言在實現上比較成熟,可以支持大量的協程同時執行,這也是 golang 能夠處理高并發的原因之一。

在 golang 中,協程的實現是基于線程的,它維護了一個協程隊列,由多個線程來負責執行協程隊列中的任務。當一個協程在執行過程中遇到了阻塞操作,比如等待 IO 數據返回,它會被放入一個阻塞隊列中,等待 IO 數據返回后再繼續執行。在這個過程中,當前線程會去執行隊列中的其他協程,從而實現協程之間的切換。

責任編輯:趙寧寧 來源: coding日記
相關推薦

2023-10-12 09:46:00

并發模型線程

2021-09-16 09:59:13

PythonJavaScript代碼

2010-11-08 13:04:36

SQL SERVER線

2023-10-11 07:39:58

Java虛擬線程

2010-07-08 16:00:51

SQL Server線

2025-06-26 04:10:00

2021-04-25 09:36:20

Go協程線程

2010-07-20 10:34:51

SQL Server線

2010-07-07 14:57:25

SQL Server線

2020-06-12 16:10:58

進程線程Java

2022-04-19 20:39:03

協程多進程

2017-08-10 15:50:44

PHP協程阻塞

2010-11-08 13:15:13

SQL SERVER線

2024-02-05 09:06:25

Python協程Asyncio庫

2023-10-24 19:37:34

協程Java

2021-09-10 17:02:43

Python協程goroutine

2021-12-09 06:41:56

Python協程多并發

2025-02-08 09:13:40

2024-06-27 07:56:49

2017-09-22 16:08:16

Python協程編程
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 色综合一区二区三区 | 成人在线视频网 | 欧美成人h版在线观看 | 日韩久草 | 亚洲图片视频一区 | 国产成人在线视频免费观看 | 亚洲高清在线 | 一区二区三区中文字幕 | 亚洲精品视频三区 | 亚州视频在线 | 精品久久久久久久久久久久久久 | 欧美aⅴ | 欧美日韩亚洲视频 | 日韩手机在线看片 | 九九久久精品 | 免费亚洲婷婷 | 国产一级大片 | 秋霞在线一区 | 亚洲国产成人精品女人久久久 | 美女爽到呻吟久久久久 | 欧美精品片 | 99视频在线免费观看 | 成人精品在线视频 | 久久久亚洲 | 毛片av免费在线观看 | 久久夜色精品国产 | 在线免费观看黄色 | 在线观看免费av网 | 日韩中文字幕在线观看 | 中文字幕第二十页 | 911精品国产 | 51ⅴ精品国产91久久久久久 | 懂色中文一区二区在线播放 | 国产成人精品久久二区二区91 | 亚洲+变态+欧美+另类+精品 | 中文字幕久久久 | 欧美在线天堂 | 日一日操一操 | 日韩高清一区 | 在线视频h | 精品国产一区二区国模嫣然 |