亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言創(chuàng)建線程thread_create()的方法

 更新時間:2021年02月04日 14:18:48   投稿:zx  
這篇文章主要介紹了C語言創(chuàng)建線程thread_create()的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

在頭文件 threads.h 中,定義和聲明了支持多線程的宏、類型和函數(shù)。所有直接與線程相關(guān)的標(biāo)識符,均以前綴 thrd_ 作為開頭。例如,thrd_t 是一個對象類型,它標(biāo)識了一個線程。

函數(shù) thrd_create()用于創(chuàng)建并開始執(zhí)行一個新線程。函數(shù) thrd_create()的其中一個參數(shù)為在新線程中需要被執(zhí)行的函數(shù) thrd_create()的其中一個參數(shù)為在新線程中需要被執(zhí)行的函數(shù)。thrd_create()的完整原型是:

int thrd_create(thrd_t *thr, thrd_start_t func, void *arg);

參數(shù) func 是一個指針,它指向在新線程需要被執(zhí)行的函數(shù),而 void 指針 arg 用于向該函數(shù)傳遞參數(shù)。換句話說,新線程將執(zhí)行函數(shù)調(diào)用 func(arg)。

參數(shù) func 的類型為 thrd_start_t,它被定義為 int(*)(void*)(這是一個函數(shù)指針,指向一個 void 指針作為其參數(shù)并返回一個 int 值的函數(shù)),因此,該線程執(zhí)行的函數(shù)返回一個 int 類型的值。

程序在后續(xù)過程中可以通過調(diào)用函數(shù) thread_join()獲得這個 int 類型的返回值(必要時,需等待該線程執(zhí)行完)。

如果一個線程啟動成功,函數(shù) thread_create()將新線程寫入一個對象進(jìn)行標(biāo)識,并通過參數(shù) thr 指向該對象,然后返回宏值 thread_success。

在大多數(shù)情況下,后續(xù)的其他操作均依賴于該線程的執(zhí)行結(jié)果,并且只有當(dāng)該線程完成后,才能執(zhí)行其他操作。函數(shù) thread_join()用于確保一個線程已完成。它的原型是:

int thrd_join(thrd_t thr, int *result);

調(diào)用 thread_join()的線程會被阻塞,直到通過 thr 標(biāo)識的線程執(zhí)行完成,這里“阻塞”(block)指的是:線程會在調(diào)用 thread_join()的位置停留必要的時間。然后,thread_join()將線程 thr 中執(zhí)行函數(shù)的返回值寫入指針 result 所引用的 int 變量中,假設(shè) result 不是一個空指針。最后,thread_join()釋放屬于線程 thr 的所有資源。

如果程序邏輯上并不需要等待線程 thr 結(jié)束,則應(yīng)該調(diào)用以下函數(shù):

int thrd_detach(thrd_t thr);

thrd_detach()使得當(dāng)線程 thr 執(zhí)行完成后,自動釋放線程占用的所有資源。一旦一個線程執(zhí)行了分離操作(調(diào)用 thrd_detach()),將不用程序等待其結(jié)束,程序也不會獲得該線程執(zhí)行函數(shù)的返回值。對于每個創(chuàng)建的線程,調(diào)用 thread_join()或 thread_detach()不得超過一次。

在例 1 中的程序展示了使用并行操作處理數(shù)組的一種方式。各個線程先自行處理數(shù)組的各部分,然后將它們的處理結(jié)果組合在一起。該程序僅需計算一個數(shù)字序列的總和。

函數(shù) sum()首先根據(jù)創(chuàng)建線程的最大數(shù)量確定劃分?jǐn)?shù)組所得的各組元素的最大數(shù)量,然后調(diào)用遞歸輔助函數(shù) parallel_sum()。

函數(shù) parallel_sum()將數(shù)組平均分為兩半,將其中的一半交給一個新線程處理,同時調(diào)用自身來處理另一半數(shù)組。如該例所示,一個線程函數(shù)需要多個參數(shù),這些參數(shù)通常采用結(jié)構(gòu)進(jìn)行封裝。

【例1】在幾個并行線程中計算數(shù)組元素的和

#include <stdbool.h>
#include <threads.h>
#define MAX_THREADS 8      // 1、2、4、8……所創(chuàng)建線程數(shù)量的最大值
#define MIN_BLOCK_SIZE 100   // 一個數(shù)組塊的最小值
typedef struct         // 函數(shù)parallel_sum()的參數(shù)
{
  float *start;    // 傳遞給parallel_sum()的數(shù)組塊的起始地址
  int len;      // 數(shù)組塊長度
  int block_size;   // 最小數(shù)組塊的大小
  double sum;         // 求和結(jié)果
} Sum_arg;
int parallel_sum(void *arg);  // 線程函數(shù)的原型
// ---------------------------------------------------------------
// 計算數(shù)組元素的和,并寫入*sumPtr
// sum()調(diào)用函數(shù)parallel_sum()進(jìn)行并行處理
// 返回值:如果沒有發(fā)生錯誤,則返回true;否則,返回false
bool sum(float arr[], int len, double* sumPtr)
{
  int block_size = len / MAX_THREADS;
  if (block_size < MIN_BLOCK_SIZE) block_size = len;
  Sum_arg args = { arr, len, block_size, 0.0 };
  if (parallel_sum(&args))
  { *sumPtr = args.sum; return true; }
  else
    return false;
}
// ---------------------------------------------------------------
// 遞歸輔助函數(shù),用以將工作分解到幾個線程中處理
int parallel_sum(void *arg)
{
  Sum_arg *argp = (Sum_arg*)arg;       // 指向參數(shù)的指針
  if (argp->len <= argp->block_size)         // 如果length <= block_size,
                            // 對所有元素求和
  {                                 
    for (int i = 0; i < argp->len; ++i)
      argp->sum += argp->start[i];
    return 1;
  }
  else                        // 如果length > block_size,
                            // 分解數(shù)組
  {                                      
    int mid = argp->len / 2;
    Sum_arg arg2 = { argp->start+mid, argp->len-mid,
             argp->block_size, 0};    // 指定后一半數(shù)組
    argp->len = mid;           // 前一半數(shù)組的長度
    thrd_t th;               // 在新線程中處理前一半數(shù)組
    int res = 0;
    if (thrd_create(&th, parallel_sum, arg) != thrd_success)
      return 0;              // 沒能成功創(chuàng)建新線程
    if (!parallel_sum(&arg2))  // 在當(dāng)前線程下,以遞歸方式處理后一半數(shù)組
    {
      thrd_detach(th); return 0;     // 遞歸調(diào)用失敗
    }
    thrd_join(th, &res);
    if (!res)
      return 0;      // 同級線程報告執(zhí)行失敗
    argp->sum += arg2.sum;
    return 1; 
  }
}

到此這篇關(guān)于C語言創(chuàng)建線程thread_create()的方法的文章就介紹到這了,更多相關(guān)C語言創(chuàng)建線程 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言數(shù)據(jù)存儲詳解

    C語言數(shù)據(jù)存儲詳解

    在本篇文章里小編給大家整理的是關(guān)C語言數(shù)據(jù)存儲,小編覺得這篇文章寫的很不錯,有需要的朋友們可以學(xué)習(xí)參考下,希望能夠給你帶來幫助
    2021-10-10
  • 讓我們一起來對C語言指針再分析

    讓我們一起來對C語言指針再分析

    這篇文章主要為大家詳細(xì)介紹C語言的指針,本文進(jìn)行了深度解析,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • 基于C++編寫一個進(jìn)度條的示例代碼

    基于C++編寫一個進(jìn)度條的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用C++實現(xiàn)一個命令行進(jìn)度條,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以了解一下
    2023-06-06
  • C++ cin.getline及getline()用法詳解

    C++ cin.getline及getline()用法詳解

    這篇文章主要介紹了C++ cin.getline用法及C++ getline()的兩種用法,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • C語言實現(xiàn)餐飲管理與點餐系統(tǒng)

    C語言實現(xiàn)餐飲管理與點餐系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)餐飲管理與點餐系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • 詳解C語言中的指針與數(shù)組的定義與使用

    詳解C語言中的指針與數(shù)組的定義與使用

    這篇文章主要介紹了C語言中的指針與數(shù)組的定義與使用,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • 詳解Qt中的雙緩沖機(jī)制與實例應(yīng)用

    詳解Qt中的雙緩沖機(jī)制與實例應(yīng)用

    所謂雙緩沖機(jī)制,是指在繪制控件時,首先將要繪制的內(nèi)容繪制在一個圖片中,再將圖片一次性地繪制到控件上。本文主要為大家介紹了Qt中的雙緩沖機(jī)制與實例應(yīng)用,希望對大家有所幫助
    2023-03-03
  • linux下c語言的多線程編程

    linux下c語言的多線程編程

    這篇文章主要介紹了linux下c語言的多線程編程,需要的朋友可以參考下
    2017-10-10
  • C語言實現(xiàn)紅黑樹的實例代碼

    C語言實現(xiàn)紅黑樹的實例代碼

    這篇文章主要介紹了C語言實現(xiàn)紅黑樹的實例代碼,有需要的朋友可以參考一下
    2013-12-12
  • 一文帶你深入了解Qt中的順序容器類與關(guān)聯(lián)容器類

    一文帶你深入了解Qt中的順序容器類與關(guān)聯(lián)容器類

    Qt中也有很多容器類,他們在存取速度、內(nèi)存開銷等方面進(jìn)行了優(yōu)化,使用起來更輕量級、更便捷,下面就跟隨小編一起來學(xué)習(xí)一下它們的具體使用吧
    2024-04-04

最新評論