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

用代碼來思考自旋鎖和信號量

Posted on 2008-04-30 16:45 MichaelCao 閱讀(988) 評論(4)  編輯 收藏 引用 所屬分類: OS
    覺得昨天的思考似乎還是不怎么過癮,有些問題還不是很清楚.到底應(yīng)用方面兩個有什么區(qū)別呢?
自己學(xué)著別人小小的動了下手.
先貼信號量的代碼.
#include<pthread.h>
#include<stdio.h>
#include<sys/time.h>

#define MAX 10
pthread_t thread[2];
pthread_mutex_t mut;
int number=0,i;

void * thread1()
{
    printf("thread1: I'm thread 1 \n");
    for(i =0;i<MAX ;i++)
    {
        printf("thread 1: number=%d \n",number);
        pthread_mutex_lock(&mut);
        number++;
        pthread_mutex_unlock(&mut);
        sleep(2);
    }
    printf("thread1: 主函數(shù)在等我完成任務(wù)嗎?\n");
    pthread_exit(NULL);
}
void *  thread2()
{
    printf("thread2: I'm thread 2 \n");
    for(i =0; i<MAX;i++)
    {
        printf("thread2 : number=%d\n",number);
        pthread_mutex_lock(&mut);
        number++;
        pthread_mutex_unlock(&mut);
        sleep(3);
    }
    printf("thread2 : 主函數(shù)在等我完成任務(wù)么?\n");
    pthread_exit(NULL);

}

void thread_create(void)
{
    /*創(chuàng)建線程*/
    pthread_create(&thread[0],NULL,thread1,NULL);
    printf("線程1被創(chuàng)建!\n");
    pthread_create(&thread[1],NULL,thread2,NULL);
    printf("線程2被創(chuàng)建!\n");
}
void thread_wait(void)
{
    /*等待線程結(jié)束*/
    pthread_join(thread[0],NULL);
    printf("線程1已經(jīng)結(jié)束!\n");
    pthread_join(thread[1],NULL);
    printf("線程2已經(jīng)結(jié)束!\n");
}
int main()
{
    /*用默認(rèn)屬性初始化互斥鎖*/
    pthread_mutex_init(&mut,NULL);
    printf("我是主函數(shù),我正在創(chuàng)建線程!\n");
    thread_create();
    printf("我是主函數(shù),我正在等待線程完成任務(wù)!\n");
    thread_wait();
}

執(zhí)行的結(jié)果是:
我是主函數(shù),我正在創(chuàng)建線程!
thread1: I'm thread 1
thread 1: number=0
線程1被創(chuàng)建!
thread2: I'm thread 2
thread2 : number=1
線程2被創(chuàng)建!
我是主函數(shù),我正在等待線程完成任務(wù)!
thread 1: number=2
thread2 : number=3
thread 1: number=4
thread 1: number=5
thread2 : number=6
thread 1: number=7
thread2 : number=8
thread 1: number=9
thread2 : number=10
thread1: 主函數(shù)在等我完成任務(wù)嗎?
線程1已經(jīng)結(jié)束!
thread2 : 主函數(shù)在等我完成任務(wù)么?
線程2已經(jīng)結(jié)束!

 重要:這個執(zhí)行的過程大概要10秒!!!!!!
而我們用自旋鎖,代碼:
/*
 * time :2008.4.30
 * author:will cao
 * Email:sei_michael@126.com
 * 探索自旋鎖與信號量的區(qū)別
 */
#include<pthread.h>
#include<stdio.h>

pthread_t thread[2];
pthread_spinlock_t lock ;

#define MAX 10

int number=0,i;

void * thread1()
{
    printf ("thread 1 :I began to run !");
    for(i=0;i<MAX;i++)
    {
        printf("thread 1 :number=%d \n",number);
        pthread_spin_lock(&lock);
        number++;
        pthread_spin_unlock(&lock);
    }
    printf("ok ,I am over !\n");
    pthread_exit(NULL);
}
void * thread2 ()
{
    printf("thread2 : I start !!!\n");
    for(i=0;i<MAX;i++)
    {
        printf("thread2 : number = %d \n",number);
        pthread_spin_lock(&lock);
        number++;
        pthread_spin_unlock(&lock);
    }
    printf("thread 2: I am over!!!");
    pthread_exit(NULL);
}

void thread_create(void)
{
    /*create the threads */
    pthread_create(&thread[0],NULL,thread1,NULL);
    printf("create the thread 1\n ");
    pthread_create(&thread[1],NULL,thread2,NULL);
    printf("create the thread 2 \n");
}
void thread_wait(void )
{
    /*wait for the thread to be over */
    pthread_join(thread[0],NULL);
    printf("the thread 1 is over !\n");
    pthread_join(thread[1],NULL);
    printf("the thread 2 is over ! \n");
}
int main()
{
    /* init the spin lock */
    pthread_spin_init(&lock,0);
    printf("i am the main,and I am creating the threads ");
    thread_create();
    printf("i am the main,and I am wait for the thread to be over!");
    thread_wait();
}
 執(zhí)行結(jié)果為:
i am the main,and I am creating the threads thread 1 :I began to run !thread 1 :number=0
thread 1 :number=1
thread 1 :number=2
thread 1 :number=3
thread 1 :number=4
thread 1 :number=5
thread 1 :number=6
thread 1 :number=7
thread 1 :number=8
thread 1 :number=9
ok ,I am over !
create the thread 1
 thread2 : I start !!!
create the thread 2
i am the main,and I am wait for the thread to be over!thread2 : number = 10
thread2 : number = 11
thread2 : number = 12
thread2 : number = 13
thread2 : number = 14
thread2 : number = 15
thread2 : number = 16
thread2 : number = 17
thread2 : number = 18
thread2 : number = 19
thread 2: I am over!!!the thread 1 is over !
the thread 2 is over !
   執(zhí)行時間:我沒用系統(tǒng)調(diào)用,但肯定是用不了0.1秒的...
總結(jié):從表面上來看,很明顯的區(qū)別是當(dāng)我們用的是信號量的時候,這個時候是有調(diào)度的.因為從運行結(jié)果上來看,主線程在創(chuàng)建其他兩個線程后,其他線程開始運行.并且主線程也在運行.但怎么運行這個是無法確定的,這是一個并發(fā)的過程.
    當(dāng)使用自旋鎖后,這個就不一樣了.當(dāng)運行到臨界區(qū)的時候,它是直接的過去,不是會產(chǎn)生一個等待,或者一個調(diào)度.
不知道編譯器是怎么編譯的.很想知道編譯后二進(jìn)制代碼有什么區(qū)別.但這個好像有點太難....不過我覺得從運行結(jié)果上來看這么多,應(yīng)該差不多了.


Feedback

# re: 用代碼來思考自旋鎖和信號量  回復(fù)  更多評論   

2008-09-19 10:01 by 郭石
博主,你前面不是在用互斥鎖嗎?哪里用了信號量呢?

# re: 用代碼來思考自旋鎖和信號量  回復(fù)  更多評論   

2008-10-27 18:27 by mach
如果把上面代碼中的sleep去掉,估計運行時間也不會超過0.1秒 哈哈

# re: 用代碼來思考自旋鎖和信號量  回復(fù)  更多評論   

2009-03-02 11:51 by galilio
只有代碼,沒有思考

# re: 用代碼來思考自旋鎖和信號量  回復(fù)  更多評論   

2009-06-02 17:34 by falconflying
我覺得樓主是想當(dāng)然了,對于spinlock的確會出現(xiàn)你所說的結(jié)果,但是也會出現(xiàn)mutex類似的結(jié)果,在我的機器上就出現(xiàn)了,redhat5 企業(yè)版
另外,mutex出現(xiàn)10秒的原因是你使用了sleep。。。。。

posts - 16, comments - 16, trackbacks - 0, articles - 0

Copyright © MichaelCao

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产麻豆日韩| 久久久久久久久久看片| 欧美中文在线观看国产| 亚洲午夜一区| 亚洲免费综合| 午夜在线精品偷拍| 欧美在线免费观看| 欧美成人按摩| 夜夜嗨av一区二区三区中文字幕 | 免费成人美女女| 免费欧美电影| 亚洲欧洲精品一区二区三区| 男人的天堂亚洲| 欧美大片91| 久久影视精品| 亚洲国产欧美日韩| 99热精品在线| 久久不射2019中文字幕| 美女主播精品视频一二三四| 欧美精品成人91久久久久久久| 欧美午夜在线| 亚洲欧洲免费视频| 久久国产精品免费一区| 亚洲激情网站| 欧美在线日韩在线| 欧美日本韩国一区| 黄色av成人| 亚洲综合欧美日韩| 欧美国产日本在线| 欧美一区二区视频网站| 欧美日本在线看| 136国产福利精品导航网址应用| 99在线|亚洲一区二区| 久久夜色精品国产| 亚洲欧美日韩国产中文| 欧美日韩高清免费| 亚洲黄色一区二区三区| 久久精品系列| 亚洲欧美激情诱惑| 欧美三区美女| 99国产精品99久久久久久粉嫩| 久久久综合精品| 午夜精品一区二区三区在线视| 欧美三级电影精品| 一本综合精品| 亚洲日本成人| 欧美黑人在线观看| 亚洲国产一区二区三区在线播 | 影音先锋久久资源网| 亚洲欧美一级二级三级| 一区二区三区国产精华| 欧美日韩精品中文字幕| 日韩视频精品| 亚洲国产成人久久综合| 快播亚洲色图| 亚洲国产婷婷香蕉久久久久久| 久久夜色精品| 玖玖精品视频| 亚洲区中文字幕| 亚洲电影自拍| 欧美国产一区二区在线观看| 亚洲精品国产视频| 亚洲人成在线观看一区二区| 欧美人成在线| 亚洲一区在线观看视频| 亚洲一区二区三区中文字幕| 国产精品视频内| 久久精品中文字幕一区| 欧美日韩第一区| 国产精品国产三级国产普通话三级| 亚洲欧洲偷拍精品| 亚洲人成网站影音先锋播放| 欧美激情视频网站| 99热在这里有精品免费| 亚洲人成网站影音先锋播放| 欧美三级免费| 久久久久久电影| 欧美成人免费在线视频| 亚洲一区二区黄色| 久久国产婷婷国产香蕉| 亚洲国产精品成人精品| 亚洲九九精品| 国产欧美日韩不卡免费| 久久riav二区三区| 久久婷婷成人综合色| 亚洲日韩欧美视频| 一区二区三区国产精品| 国产一区二区三区直播精品电影| 久久午夜av| 欧美剧在线观看| 久久av一区| 久久中文字幕一区二区三区| 久久亚洲一区二区| 亚洲女性喷水在线观看一区| 久久久999| 亚洲一区二区成人| 久久久999国产| 亚洲一区二区在线免费观看| 久久精品国产亚洲一区二区三区 | 亚洲国产精品尤物yw在线观看| 国产精品ⅴa在线观看h| 久久手机精品视频| 欧美久久精品午夜青青大伊人| 西瓜成人精品人成网站| 蜜桃av一区二区三区| 欧美在线一级va免费观看| 欧美电影免费观看高清完整版| 久久成人人人人精品欧| 欧美视频日韩视频| 亚洲第一综合天堂另类专| 国产精品综合| 99视频超级精品| 亚洲国产精品一区二区久| 欧美一级一区| 亚洲在线播放| 欧美日韩1区| 亚洲第一精品夜夜躁人人爽| 国产亚洲精品久久久久婷婷瑜伽| 亚洲日本视频| 亚洲精品视频在线观看网站| 久久精品123| 久久久久**毛片大全| 国产精品美女久久久| 亚洲免费av网站| 亚洲精品中文字幕在线| 久久久久久成人| 久久久蜜桃精品| 国产精品羞羞答答| 中文国产成人精品久久一| 日韩手机在线导航| 国产精品久线观看视频| 在线观看日韩av先锋影音电影院| 国产精品99一区| 国产精品永久在线| 欧美午夜激情视频| 国产伊人精品| 国产自产高清不卡| 日韩一区二区高清| 亚洲综合第一页| 久久亚洲私人国产精品va| 欧美影院成人| 亚洲人成网站影音先锋播放| 亚洲欧洲日韩在线| 午夜久久美女| 免费日韩成人| 国产精品麻豆欧美日韩ww| 亚洲国产精品123| 亚洲欧美中文另类| 亚洲大胆在线| 久久精品九九| 国产日韩欧美麻豆| 日韩视频―中文字幕| 免费视频久久| 欧美伊人久久| 欧美色道久久88综合亚洲精品| 影音先锋一区| 久久精品盗摄| 欧美一区三区三区高中清蜜桃| 欧美大香线蕉线伊人久久国产精品| 欧美日韩播放| 亚洲精品国产精品乱码不99按摩| 久久久久久久精| 午夜国产欧美理论在线播放| 久久国产精品一区二区| 国产欧美欧美| 午夜激情亚洲| 亚洲欧美日韩精品一区二区| 欧美母乳在线| 9色porny自拍视频一区二区| 亚洲精品久久久久久下一站| 免费亚洲电影在线观看| 亚洲激情不卡| 亚洲精品护士| 美女爽到呻吟久久久久| 欧美一区二区三区视频免费播放| 国产欧美一区二区三区在线看蜜臀| 午夜精品在线看| 久久精品国产一区二区三区免费看 | 久久成人资源| 国产精品一二三四区| 久久本道综合色狠狠五月| 午夜精品免费在线| 亚洲人成在线免费观看| 99国产精品久久久久久久久久| 国产精品久久久久久久浪潮网站 | 欧美片第一页| 久久精品网址| 国产麻豆综合| 亚洲视频在线观看一区| 99热免费精品在线观看| 久久国产免费| 麻豆成人精品| 国产精品五区| 99riav久久精品riav| 在线欧美小视频| 久久亚洲电影| 美女视频黄 久久| 国产一区二区三区高清| 午夜免费日韩视频| 欧美亚洲视频在线观看|