国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

查看: 2474|回復: 0
打印 上一主題 下一主題

Linux多線程及線程間同步

[復制鏈接]
跳轉到指定樓層
樓主
發表于 2017-9-9 09:41:48 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
1、進程和線程的區別
進程的目的就是擔當分配系統資源(CPU時間、內存等)的基本單位。線程是進程的一個執行流,是CPU調度和分派的基本單位,它是比進程更小的能獨立運行的基本單位。一個進程由幾個線程組成,線程與同屬一個進程的其他的線程共享進程所擁有的全部資源。

地址空間:進程有獨立的地址空間,包括文本區域(text region)、數據區域(data region)和堆棧(stack region);一個進程崩潰后,在保護模式下不會對其它進程產生影響;線程只是一個進程中的不同執行路徑,線程有自己的堆棧和局部變量(在運行中必不可少的資源),但線程之間沒有單獨的地址空間,一個線程死掉就等于整個進程死掉。同一進程內的線程共享進程的地址空間。

通信:進程間通信IPC,線程間可以直接讀寫進程數據段(如全局變量)來進行通信——需要進程同步和互斥手段的輔助,以保證數據的一致性。

調度和切換:線程上下文切換比進程上下文切換要快得多。

在多線程OS中,進程不是一個可執行的實體。

地址空間:進程內的一個執行單元;進程至少有一個線程;它們共享進程的地址空間;而進程有自己獨立的地址空間;

資源擁有:進程是資源分配和擁有的單位,同一個進程內的線程共享進程的資源

線程是處理器調度的基本單位,但進程不是.

二者均可并發執行.

2、使用線程原因
    在Linux系統下,啟動一個新的進程必須分配給它獨立的地址空間,建立眾多的數據表來維護它的代碼段、堆棧段和數據段,這是一種"昂貴"的多任務工作方式。而運行于一個進程中的多個線程,它們彼此之間使用相同的地址空間,共享大部分數據,啟動一個線程所花費的空間遠遠小于啟動一個進程所花費的空間,而且,線程間彼此切換所需的時間也遠遠小于進程間切換所需要的時間。
    線程間方便的通信機制。對不同進程來說,它們具有獨立的數據空間,要進行數據的傳遞只能通過通信的方式進行,這種方式不僅費時,而且很不方便。線程則不然,由于同一進程下的線程之間共享數據空間,所以一個線程的數據可以直接為其它線程所用,這不僅快捷,而且方便。


3、線程操作的函數
#include   
int pthread_create(pthread_t *tid, const pthread_attr_t *attr, void *(*func) (void *), void *arg);
int pthread_join (pthread_t tid, void ** status);
pthread_t pthread_self (void);
int pthread_detach (pthread_t tid);
void pthread_exit (void *status);

pthread_create:用于創建一個線程,成功返回0,否則返回Exxx(為正數)。
pthread_t *tid:線程id的類型為pthread_t,通常為無符號整型,當調用pthread_create成功時,通過*tid指針返回。

const pthread_attr_t *attr:指定創建線程的屬性,如線程優先級、初始棧大小、是否為守護進程等。可以使用NULL來使用默認值,通常情況下我們都是使用默認值。

void *(*func) (void *):函數指針func,指定當新的線程創建之后,將執行的函數。

void *arg:線程將執行的函數的參數。如果想傳遞多個參數,請將它們封裝在一個結構體中。

pthread_join:用于等待某個線程退出,成功返回0,否則返回Exxx(為正數)。
pthread_t tid:指定要等待的線程ID

void ** status:如果不為NULL,那么線程的返回值存儲在status指向的空間中(這就是為什么status是二級指針的原因!這種才參數也稱為“值-結果”參數)。

pthread_self:用于返回當前線程的ID。
pthread_detach:用于是指定線程變為分離狀態,就像進程脫離終端而變為后臺進程類似。成功返回0,否則返回Exxx(為正數)。變為分離狀態的線程,如果線程退出,它的所有資源將全部釋放。而如果不是分離狀態,線程必須保留它的線程ID,退出狀態直到其它線程對它調用了pthread_join。
pthread_exit用于終止線程,可以指定返回值,以便其他線程通過pthread_join函數獲取該線程的返回值。
void *status:指針線程終止的返回值。

4、線程間互斥
    使用互斥鎖(互斥)可以使線程按順序執行。通常,互斥鎖通過確保一次只有一個線程執行代碼的臨界段來同步多個線程。互斥鎖還可以保護單線程代碼。
int pthread_mutex_lock(pthread_mutex_t * mptr);  
int pthread_mutex_unlock(pthread_mutex_t * mptr);

先聲明一個pthread_mutex_t類型的變量,用作下面兩個函數的參數。在對臨界資源進行操作之前需要pthread_mutex_lock先加鎖,操作完之后pthread_mutex_unlock再解鎖。


5、線程間同步
條件變量:使用條件變量可以以原子方式阻塞線程,直到某個特定條件為真為止。條件變量始終與互斥鎖一起使用。對條件的測試是在互斥鎖(互斥)的保護下進行的。
#include   
int pthread_cond_wait(pthread_cond_t *cptr, pthread_mutex_t *mptr);  
int pthread_cond_signal(pthread_cond_t *cptr);  
//Both return: 0 if OK, positive Exxx value on error

pthread_cond_wait用于等待某個特定的條件為真,pthread_cond_signal用于通知阻塞的線程某個特定的條件為真了。在調用者兩個函數之前需要聲明一個pthread_cond_t類型的變量,用于這兩個函數的參數。
/*
是否熟悉POSIX多線程編程技術?如熟悉,編寫程序完成如下功能:
  1)有一int型全局變量g_Flag初始值為0;
  2)在主線稱中起動線程1,打印“this is thread1”,并將g_Flag設置為1
  3)在主線稱中啟動線程2,打印“this is thread2”,并將g_Flag設置為2
  4)線程序1需要在線程2退出后才能退出
  5)主線程在檢測到g_Flag從1變為2,或者從2變為1的時候退出



以下課程可免費試聽C語言電子PCBSTM32、Linux、FPGA、JAVA、安卓等。
想學習的你和我聯系預約就可以免費聽課了。
宋工企鵝號:3524-6590-88   Tel/WX:173--1795--1908






您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产三级小视频 | 久久久久毛片免费观看 | 99国产牛牛视频在线网站 | a一级一色一情 | 亚洲国产精品自在现线让你爽 | 一级二级毛片 | 国产精品臀控福利在线观看 | 欧美xart系列高清在线视频 | 免费一级片在线 | 色婷五月 | 亚洲欧美日韩天堂在线观看 | 亚洲成人三级 | 在线观看不卡视频 | 日本免费一区二区三区中文 | 九九热视频精品在线 | 热re91久久精品国产91热 | 久热这里只有精品99国产6 | 男女羞羞羞视频午夜视频 | 污污的网站在线免费观看 | 性欧美性欧美 | 国产噜噜噜精品免费 | 亚洲精品国产成人中文 | 亚洲a在线视频 | 天天综合欧美 | 成人99 | 久久精品国产曰本波多野结衣 | 黄页网站| 99re这里只有精品在线观看 | 麻豆国产精品免费视频 | 亚洲欧洲国产视频 | 亚洲 欧美 日韩在线一区 | 成年人免费在线视频网站 | 久久精品国产2020 | 上海一级片 | 天堂最新版资源www在线 | 年轻的馊子hd中文播放 | 一级a毛片免费观看久久精品 | 青青青国产在线视频 | 国产精品福利在线 | 四虎网址大全 | 91高清完整版在线观看 |