在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux的C編程中多線程如何終止某個線程示例與要點

FPGA之家 ? 來源:CSDN技術(shù)社區(qū) ? 作者:老吳的嵌入式之旅 ? 2021-04-27 13:41 ? 次閱讀

示例 demo

最簡單的 demo:

static void* thread1_func(void *arg)

{

int i = 0;

// able to be cancel

pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL);

pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, NULL);

for(i=0; ; i++) {

printf(“thread1 %d

”, i);

sleep(1);

}

}

int main(int argc, char **argv)

{

pthread_t t;

void *res;

pthread_create(&t, NULL, thread1_func, NULL);

sleep(3);

pthread_cancel(t); // cancel thread1

pthread_join(t, &res); // wait thread1

if (res == PTHREAD_CANCELED

printf(“thread1 was terminate by cancel

”);

else

printf(“thread1 was not terminate by cancel

”);

exit(EXIT_SUCCESS);

}

為了突出重點,省略了檢查返回值。

運行效果:

thread1 0

thread1 1

thread1 2

thread1 was terminate by cancel

主線程先創(chuàng)建線程 thread1,然后睡眠 3 秒后發(fā)出終止 thread1 的請求。

接收到終止請求后,thread1 會在合適的時機被終止掉。

主線程通過 pthread_join() 阻塞等待 thread1 退出。

幾個要點

線程終止的 4 種方式:

線程的執(zhí)行函數(shù)返回了,這和 main() 函數(shù)結(jié)束類似。

線程調(diào)用了 pthread_exit() 函數(shù),這和調(diào)用 exit() 返回類似。

線程被另一個線程通過 pthread_cancel() 函數(shù)取消,這和通過kill() 發(fā)送 SIGKILL 信號類似。

進(jìn)程終止了,則進(jìn)程中的所有線程也會終止。

取消某個線程的常規(guī)步驟

被取消的線程:

允許取消,pthread_setcancelstate(),參數(shù)可選值:

PTHREAD_CANCEL_ENABLE,這是默認(rèn)值;

PTHREAD_CANCEL_DISABLE;

設(shè)置取消類型,pthread_setcanceltype(),參數(shù)可選值:

PTHREAD_CANCEL_ASYNCHRONOUS,異步方式,當(dāng)發(fā)出取消請求后,線程可能會在任何點被殺死。

PTHREAD_CANCEL_DEFERRED,延遲方式,線程只會在特定的取消點(cancellation points,調(diào)用某個函數(shù)前)被殺死。

發(fā)起取消的線程:

發(fā)送取消要求,pthread_cancel(),發(fā)出取消請求后,pthread_cancel() 當(dāng)即返回,不會等待目標(biāo)線程的退出。

等待取消完成,pthread_join()。

哪些函數(shù)是取消點?

POSIX.1 指定了哪些函數(shù)一定是取消點:

6db9b9f8-a67e-11eb-aece-12bb97331649.png

更多關(guān)于取消點的介紹:

$ man 7 pthreads

Cancellation points

。..

accept()

aio_suspend()

clock_nanosleep()

close()

。..

閱讀開源軟件 MJPG-streamer

MJPG-streamer 是什么?

簡單地說,就是一個開源的流媒體服務(wù)器:

https://github.com/jacksonliam/mjpg-streamer

通過 mjpg-streamer,你可以通過 PC 瀏覽器訪問到板子上的攝像頭圖像。

MJPG-streamer 是如何結(jié)束工作線程的?

MJPG-streamer 運行時一般會有 3 個線程:

主線程;

負(fù)責(zé)數(shù)據(jù)的輸入的線程 (例如 camera capture thread);

負(fù)責(zé)輸出數(shù)據(jù)的線程 (例如 http server thread)。

以 http server thread 為例:

plugins/output_http/httpd.c

void *server_thread(void *arg)

{

。..

pthread_cleanup_push(server_cleanup, pcontext);

// 處理連接

while(!pglobal-》stop) {

。..

}

pthread_cleanup_pop(1);

}

pthread_cleanup_push() 用于注冊清理函數(shù)到棧中,當(dāng)線程遭取消時,會沿該棧自頂向下依次執(zhí)行清理函數(shù)。

當(dāng)用戶通過按下 ctrl + c 要求結(jié)束程序時,主線程會要求殺掉 http server thread 等各種線程:

static void signal_handler(int sig)

{

for(i = 0; i 《 global.outcnt; i++) {

。..

pthread_cancel(servers[id].threadID);

。..

}

}

接下來,當(dāng) http server thread 遇到某個取消點時,server_cleanup() 會被調(diào)用以完成清理工作。

這里只是簡單地分析一下,MJPG-Streamer 里多線程相關(guān)的代碼挺復(fù)雜的,有興趣的小伙伴們自行閱讀吧。
編輯:lyn

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11379

    瀏覽量

    211353
  • 多線程
    +關(guān)注

    關(guān)注

    0

    文章

    278

    瀏覽量

    20111
  • c編程
    +關(guān)注

    關(guān)注

    0

    文章

    94

    瀏覽量

    29437

原文標(biāo)題:Linux-C編程 / 多線程 / 如何終止某個線程?

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    請問如何在Python實現(xiàn)多線程與多進(jìn)程的協(xié)作?

    大家好!我最近在開發(fā)一個Python項目時,需要同時處理多個任務(wù),且每個任務(wù)需要不同的計算資源。我想通過多線程和多進(jìn)程的組合來實現(xiàn)并發(fā),但遇到了一些問題。 具體來說,我有兩個任務(wù),一個是I/O密集型
    發(fā)表于 03-11 06:57

    請問rt-thread studio如何進(jìn)行多線程編譯?

    ,使用的是5800h+32g內(nèi)存+sn550 ssd,開啟16線程編譯時cpu的占用率也只能到30%,編譯完整個工程需要3分鐘 感覺多線程編譯設(shè)置沒有生效,有辦法提高編譯速度嗎
    發(fā)表于 02-19 08:30

    socket 多線程編程實現(xiàn)方法

    在現(xiàn)代網(wǎng)絡(luò)編程多線程技術(shù)被廣泛應(yīng)用于提高服務(wù)器的并發(fā)處理能力。Socket編程是網(wǎng)絡(luò)通信的基礎(chǔ),而將多線程技術(shù)應(yīng)用于Socket
    的頭像 發(fā)表于 11-12 14:16 ?580次閱讀

    Python多線程和多進(jìn)程的區(qū)別

    Python作為一種高級編程語言,提供了多種并發(fā)編程的方式,其中多線程與多進(jìn)程是最常見的兩種方式之一。在本文中,我們將探討Python多線程
    的頭像 發(fā)表于 10-23 11:48 ?629次閱讀
    Python<b class='flag-5'>中</b><b class='flag-5'>多線程</b>和多進(jìn)程的區(qū)別

    一文掌握Python多線程

    使用線程可以把占據(jù)長時間的程序的任務(wù)放到后臺去處理。
    的頭像 發(fā)表于 08-05 15:46 ?990次閱讀

    ESP32會不會有多線程問題,需要加鎖嗎?

    ESP32會不會有多線程問題,需要加鎖嗎
    發(fā)表于 07-19 08:05

    多線程設(shè)計模式到對 CompletableFuture 的應(yīng)用

    最近在開發(fā) 延保服務(wù) 頻道頁時,為了提高查詢效率,使用到了多線程技術(shù)。為了對多線程方案設(shè)計有更加充分的了解,在業(yè)余時間讀完了《圖解 Java 多線程設(shè)計模式》這本書,覺得收獲良多。本篇文章將介紹其中
    的頭像 發(fā)表于 06-26 14:18 ?474次閱讀
    從<b class='flag-5'>多線程</b>設(shè)計模式到對 CompletableFuture 的應(yīng)用

    鴻蒙開發(fā):【線程模型】

    管理其他線程的ArkTS引擎實例,例如使用TaskPool(任務(wù)池)創(chuàng)建任務(wù)或取消任務(wù)、啟動和終止Worker線程
    的頭像 發(fā)表于 06-13 16:38 ?517次閱讀
    鴻蒙開發(fā):【<b class='flag-5'>線程</b>模型】

    bootloader開多線程做引導(dǎo)程序,跳app初始化后直接進(jìn)hardfualt,為什么?

    如標(biāo)題,想做一個遠(yuǎn)程升級的項目,bootloader引導(dǎo)區(qū)域和app都是開多線程跑的,就是自己寫了個小的任務(wù)調(diào)度器,沒什么功能主要是想讓程序快速的響應(yīng),延時不會對其他程序造成堵塞,程序測試
    發(fā)表于 04-18 06:07

    鴻蒙OS開發(fā)實例:【ArkTS類庫多線程CPU密集型任務(wù)TaskPool】

    CPU密集型任務(wù)是指需要占用系統(tǒng)資源處理大量計算能力的任務(wù),需要長時間運行,這段時間會阻塞線程其它事件的處理,不適宜放在主線程進(jìn)行。例如圖像處理、視頻編碼、數(shù)據(jù)分析等。 基于多線程并發(fā)機制處理CPU密集型任務(wù)可以提高CPU
    的頭像 發(fā)表于 04-01 22:25 ?974次閱讀
    鴻蒙OS開發(fā)實例:【ArkTS類庫<b class='flag-5'>多線程</b>CPU密集型任務(wù)TaskPool】

    鴻蒙APP開發(fā):【ArkTS類庫多線程】TaskPool和Worker的對比(2)

    創(chuàng)建Worker的線程稱為宿主線程(不一定是主線程,工作線程也支持創(chuàng)建Worker子線程),Worker自身的
    的頭像 發(fā)表于 03-27 15:44 ?621次閱讀
    鴻蒙APP開發(fā):【ArkTS類庫<b class='flag-5'>多線程</b>】TaskPool和Worker的對比(2)

    鴻蒙APP開發(fā):【ArkTS類庫多線程】TaskPool和Worker的對比

    TaskPool(任務(wù)池)和Worker的作用是為應(yīng)用程序提供一個多線程的運行環(huán)境,用于處理耗時的計算任務(wù)或其他密集型任務(wù)。可以有效地避免這些任務(wù)阻塞主線程,從而最大化系統(tǒng)的利用率,降低整體資源消耗,并提高系統(tǒng)的整體性能。
    的頭像 發(fā)表于 03-26 22:09 ?767次閱讀
    鴻蒙APP開發(fā):【ArkTS類庫<b class='flag-5'>多線程</b>】TaskPool和Worker的對比

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語言基礎(chǔ)類庫多線程TaskPool和Worker的對比(一)

    TaskPool(任務(wù)池)和Worker的作用是為應(yīng)用程序提供一個多線程的運行環(huán)境,用于處理耗時的計算任務(wù)或其他密集型任務(wù)。可以有效地避免這些任務(wù)阻塞主線程,從而最大化系統(tǒng)的利用率,降低整體資源消耗
    發(fā)表于 03-25 14:11

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語言基礎(chǔ)類庫多線程I/O密集型任務(wù)開發(fā)

    使用異步并發(fā)可以解決單次I/O任務(wù)阻塞的問題,但是如果遇到I/O密集型任務(wù),同樣會阻塞線程其它任務(wù)的執(zhí)行,這時需要使用多線程并發(fā)能力來進(jìn)行解決。 I/O密集型任務(wù)的性能重點通常不在于CPU的處理
    發(fā)表于 03-21 14:57

    java實現(xiàn)多線程的幾種方式

    Java實現(xiàn)多線程的幾種方式 多線程是指程序包含了兩個或以上的線程,每個線程都可以并行執(zhí)行不同的任務(wù)或操作。Java
    的頭像 發(fā)表于 03-14 16:55 ?859次閱讀
    主站蜘蛛池模板: 欧美一区二区三区激情啪啪 | 精品久久久久久午夜 | 大量国产后进翘臀视频 | 亚洲精品aaa揭晓 | 成人女人a毛片在线看 | 一级做a爱片特黄在线观看 一级做a爱片特黄在线观看免费看 | 中文天堂在线www | 免费精品99久久国产综合精品 | аⅴ资源天堂8在线 | 国产特黄一级一片免费 | 夜夜操狠狠操 | 伊人久久大香线蕉综合影 | 丁香六月 久久久 | 开心激情五月网 | 天天操丝袜 | 成人综合激情 | 伊人97在线 | 午夜国产精品免费观看 | 亚洲午夜顶级嘿嘿嘿影院 | 天堂网在线.www天堂在线资源 | 人人骚 | 啪啪.com| 色妞基地 | 入逼视频 | 2021久久天天躁狠狠躁夜夜 | 色五五月五月开 | 欧美婷婷六月丁香综合色 | 日本免费黄视频 | 久久综合色婷婷 | 国产成人一区二区在线不卡 | 一级黄色片在线看 | 午夜高清视频在线观看 | 天天色天天色 | 日本在线观看www | 美女网站一区二区三区 | 人人干天天干 | 一级一片免费视频播放 | 久久综合狠狠综合狠狠 | 国产福利在线观看一区二区 | 天堂男人在线 | 午夜影院网页 |