青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

T9的空間

You will never walk alone!

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  69 隨筆 :: 0 文章 :: 28 評論 :: 0 Trackbacks

線程控制

APUE講的destroy會free空間,這件事情看起來不太對,也許是Base on實現(xiàn)
起碼我看到的實現(xiàn)是沒有做這件事情的。

 

int pthread_attr_init(pthread_attr_t * attr)
{
    
*attr = gDefaultPthreadAttr;
    
return 0;
}


int pthread_attr_destroy(pthread_attr_t * attr)
{
    memset(attr, 
0x42sizeof(pthread_attr_t));
    
return 0;
}


Attribution有下面這些。

 

typedef struct
{
    uint32_t flags;
    
void * stack_base;
    size_t stack_size;
    size_t guard_size;
    int32_t sched_policy;
    int32_t sched_priority;
}
 pthread_attr_t;

我們可以用malloc和mmap給Thread分配stack,指定stack大小和位置(低地址)

mutex屬性
兩個東西
1.進(jìn)程共享屬性,PTHREAD_PROCESS_PRIVATE or SHARED
意思是說如果這個Mutex是分配在兩個進(jìn)程共享的memory,然后設(shè)置為shared mutex就可以用于進(jìn)程同步
2.類型屬性,normal;errorcheck;recurive
意思是定義Mutex本身的特性,這里更正下前面那章提到的錯誤
只有normal的mutex才會在再次加鎖時發(fā)生deadlock
errorcheck的會直接返回錯誤
recurive本身就允許,會有計數(shù)

rw lock和condition屬性
只支持第一個

TLS變量
先看下TLS的位置

 * +---------------------------+
 
* |     pthread_internal_t    |
 
* +---------------------------+
 
* |                           |
 
* |          TLS area         |
 
* |                           |
 
* +---------------------------+
 
* |                           |
 
* .                           .
 
* .         stack area        .
 
* .                           .
 
* |                           |
 
* +---------------------------+
 
* |         guard page        |
 
* +---------------------------+

pthread_internal_t是記錄線程自己本身的一些屬性的變量,guard page就是線程attr上設(shè)置的防止棧溢出的擴(kuò)展內(nèi)存

創(chuàng)建TLS變量的方法
1.創(chuàng)建Key,這個Key是這個Process中所有Thread可以共享訪問的,然后每個Thread自己去關(guān)聯(lián)自己的Thread Local變量
int pthread_key_create(pthread_key_t *keyp, void (*destructor)(void*))
創(chuàng)建key的時候需要保證唯一調(diào)用,也就是不會有兩個Thread同時調(diào)用,然后發(fā)生一些base on實現(xiàn)的不確定的結(jié)果,可以使用pthread_once

pthread_once的實現(xiàn)很簡單,用mutex做互斥量保證pthread_once_t的訪問,然后利用pthread_once_t做flag來調(diào)用init_routine

int  pthread_once( pthread_once_t*  once_control,  void (*init_routine)(void) )
{
    
static pthread_mutex_t   once_lock = PTHREAD_RECURSIVE_MUTEX_INITIALIZER;
    
volatile pthread_once_t* ocptr = once_control;

    pthread_once_t tmp 
= *ocptr;
    ANDROID_MEMBAR_FULL();
    
if (tmp == PTHREAD_ONCE_INIT) {
        pthread_mutex_lock( 
&once_lock );
        
if (*ocptr == PTHREAD_ONCE_INIT) {
            (
*init_routine)();
            ANDROID_MEMBAR_FULL();
            
*ocptr = ~PTHREAD_ONCE_INIT;
        }

        pthread_mutex_unlock( 
&once_lock );
    }

    
return 0;
}

所以這個pthread_once_t必須是全局or靜態(tài)變量
pthread_once最常用的case除了拿到TLS key外,init函數(shù)經(jīng)常會使用這個,避免多線程同時調(diào)用。

然后就是thread cancel
Android Bionic庫沒有實現(xiàn) pthread_setcancelstate(int state, int* oldstate)以及pthread_cancel()
這里thread的取消,有些是取消不掉的,例如一些blocking call,所有的取消均是需要設(shè)定一些取消點的,

有人有專門針對Android沒有Thread Cancel來想辦法
基本就是thread signal,在signal handler中去call pthread_exit();
or用PIPE在多路復(fù)用中break出來
http://blog.csdn.net/langresser/article/details/8531112

如果信號與硬件故障or計時器超時相關(guān),那么信號會發(fā)送到引起事件的該線程中去,其他信號會發(fā)送到任意一個線程。
這里是說的POSIX線程模型,一般的信號都會發(fā)送給進(jìn)程中沒有阻塞該信號的某個線程。APUE講的某個沒有阻塞該信號的線程,其實有點模糊。

但是Linux的實現(xiàn)不一樣,linux的thread是clone出來的,就是共享資源的獨立進(jìn)程,這樣子其實蠻自然的,也不容易復(fù)雜。
linux中,有可能線程就不會注意到該信號,這樣講也有點模糊,總之終端驅(qū)動程序的信號會將信號通知到進(jìn)程組,這樣子所有的thread就會都收到信號
如果你不想所有的線程都去關(guān)心信號,那么可以使用一個專門處理信號的線程
先將其他線程的signal都pthread_sigmask SIG_BLOCK掉,然后使用sigwait在特定的線程來等
pthread_sigmask和sigprocmask很像

thread與fork
fork后的子進(jìn)程會繼承mutex, rw lock, condition的狀態(tài)
但是子進(jìn)程中只會存在一個線程,也就是那個調(diào)用fork的線程的副本,有個復(fù)雜的事情是關(guān)于上面繼承下來的那些東西,子進(jìn)程由于只有一個線程,沒辦法知道
上面那三個東西的具體狀態(tài),需要有個清理鎖的動作 -->pthread_atfork(void (*prepare)(void), void (*parent)(void), void (*child)(void))
我目前不知道這個東西的使用場景,而且不容易控制。
因為一般如果我們fork后都會接execu,這樣地址空間就會改變,那么這些繼承的東西就沒用了。

然后有談一點關(guān)于線程IO的東西
pwrite/pread
也就是原子的進(jìn)行l(wèi)seek和r/w,但是這個并不能保證大家常見的沖突問題,也就是一個thread在寫另外一個要讀,所以這兩個東西并不能解決同步的問題。

作業(yè):
12.3 理論上函數(shù)開始時屏蔽所有信號,函數(shù)結(jié)束時恢復(fù),是可以做到異步信號安全的。如果你只是屏蔽一些信號,那么沒辦法做到,因為如果有其他信號進(jìn)來,你call的函數(shù)里面有一些不可重入的函數(shù),同樣不能保證是異步安全的。

12.5 fork可以在拿來執(zhí)行可執(zhí)行程序,現(xiàn)在應(yīng)該就這一個Case。

posted on 2013-06-04 15:41 Torres 閱讀(296) 評論(0)  編輯 收藏 引用 所屬分類: APUE
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美一区二区日韩一区二区| 亚洲国产天堂久久综合网| 欧美va天堂va视频va在线| 这里只有精品丝袜| 99视频超级精品| 99精品国产高清一区二区| 亚洲精品护士| 亚洲无亚洲人成网站77777| 亚洲视频狠狠| 久久激情视频久久| 免费人成网站在线观看欧美高清| 美女网站久久| 91久久精品国产91久久性色tv| 亚洲精品一区二区三区四区高清| 欧美在线观看视频一区二区三区 | 欧美一区二区国产| 欧美一区视频| 欧美搞黄网站| 国产精品sm| 黄色日韩网站| 野花国产精品入口| 欧美在线视频播放| 亚洲欧洲日产国码二区| 性色av一区二区三区在线观看 | 欧美一区日本一区韩国一区| 久久亚洲美女| 99精品视频免费观看| 亚洲校园激情| 欧美成人免费一级人片100| 国产精品久久久久久影院8一贰佰| 国产一区二区三区久久 | 亚洲伦理在线| 欧美影视一区| 亚洲黄色一区| 久久精品国产999大香线蕉| 欧美岛国激情| 国内精品写真在线观看| 亚洲午夜精品| 亚洲国产精品美女| 欧美综合二区| 国产精品一区二区久久久| 一本久久青青| 亚洲成人资源网| 久久美女性网| 好吊妞这里只有精品| 午夜欧美精品| 在线亚洲欧美专区二区| 欧美国产日韩xxxxx| 黄色成人在线网址| 午夜激情综合网| 日韩午夜中文字幕| 欧美黑人国产人伦爽爽爽| 一区二区三区无毛| 久久婷婷综合激情| 午夜一区二区三区在线观看| 国产精品久久77777| 亚洲午夜伦理| 亚洲视频第一页| 国产精品推荐精品| 午夜精品婷婷| 亚洲一区二区三区精品视频 | 亚洲精品一区中文| 欧美日韩精品免费观看视一区二区 | 亚洲二区在线观看| 久久综合给合久久狠狠色| 亚欧成人在线| 国产三级欧美三级| 久久久久久9999| 久久久国产成人精品| 在线电影欧美日韩一区二区私密| 久久只有精品| 免费黄网站欧美| 一本大道久久精品懂色aⅴ| 亚洲免费黄色| 国产麻豆精品视频| 久久精品中文字幕一区二区三区| 午夜精彩国产免费不卡不顿大片| 国产欧美日本一区二区三区| 久久久久久久久蜜桃| 久久琪琪电影院| 一本色道久久| 亚洲欧美色一区| 在线观看欧美精品| 亚洲国产婷婷香蕉久久久久久| 欧美色图首页| 久久国产视频网站| 六月婷婷一区| 亚洲欧美日韩一区| 久久久久久久久久久成人| 亚洲欧洲日韩女同| 亚洲男同1069视频| 亚洲丶国产丶欧美一区二区三区| 亚洲欧洲在线看| 国产一区 二区 三区一级| 欧美激情aⅴ一区二区三区| 欧美四级在线观看| 巨乳诱惑日韩免费av| 欧美午夜无遮挡| 蜜桃精品久久久久久久免费影院| 欧美日韩一区自拍| 麻豆乱码国产一区二区三区| 欧美手机在线视频| 欧美韩国日本一区| 国产精品视频最多的网站| 欧美激情一区二区三区在线视频| 国产精品一区2区| 亚洲日本va午夜在线电影| 国内精品视频在线观看| 亚洲私拍自拍| 在线亚洲激情| 免费欧美在线| 久久免费视频网站| 国产精品视频内| 亚洲麻豆国产自偷在线| 亚洲二区在线观看| 久久se精品一区精品二区| 性8sex亚洲区入口| 欧美日韩亚洲一区二| 欧美高清在线播放| 国语自产精品视频在线看| 亚洲一区区二区| 中文精品视频一区二区在线观看| 麻豆av福利av久久av| 久久这里只有精品视频首页| 国产日韩欧美综合在线| 亚洲欧美日本国产专区一区| 久久精品国产亚洲高清剧情介绍| 欧美久久久久久久| 亚洲国产精品一区制服丝袜| 在线电影院国产精品| 欧美在线观看网址综合| 久久9热精品视频| 国产精品视频一二三| 亚洲视频一二| 新狼窝色av性久久久久久| 国产欧美亚洲一区| 午夜日本精品| 久久精品动漫| 激情综合自拍| 免费欧美在线视频| 亚洲日本无吗高清不卡| 99国产一区| 国产精品国色综合久久| 在线亚洲精品| 欧美亚洲免费在线| 国产伦精品一区二区三区四区免费 | 欧美日韩国产综合网 | 欧美大秀在线观看| 日韩视频在线一区二区| 欧美另类videos死尸| 一区二区精品在线观看| 亚洲一区欧美一区| 国产一区二区久久久| 久久网站免费| 99国产精品久久久| 久久国产精品久久久久久久久久| 国内在线观看一区二区三区| 麻豆国产精品777777在线| 亚洲人屁股眼子交8| 午夜国产一区| 亚洲电影第1页| 欧美日韩中文在线观看| 欧美亚洲日本网站| 欧美韩日精品| 亚洲午夜视频在线| 狠狠干成人综合网| 欧美激情2020午夜免费观看| 亚洲曰本av电影| 欧美成人免费在线视频| 亚洲宅男天堂在线观看无病毒| 国产综合精品一区| 欧美精品国产一区二区| 香蕉视频成人在线观看| 亚洲国产毛片完整版| 久久黄色网页| 一区二区三区视频在线播放| 国产网站欧美日韩免费精品在线观看| 美乳少妇欧美精品| 亚洲欧美综合一区| 日韩午夜激情电影| 另类酷文…触手系列精品集v1小说| 一本在线高清不卡dvd | 米奇777在线欧美播放| 亚洲视频碰碰| 欧美激情欧美激情在线五月| 亚洲欧美日韩天堂| 亚洲国产一二三| 国产午夜久久| 欧美日本久久| 久久夜色精品| 午夜精品区一区二区三| 日韩视频免费大全中文字幕| 老司机精品导航| 欧美中文字幕久久| 亚洲一区二区精品在线| 亚洲精品美女91| 在线日韩av永久免费观看| 国产免费观看久久黄| 欧美三级资源在线| 欧美日韩一区二区三区免费看|