• <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>

            網絡服務器軟件開發/中間件開發,關注ACE/ICE/boost

            C++博客 首頁 新隨筆 聯系 聚合 管理
              152 Posts :: 3 Stories :: 172 Comments :: 0 Trackbacks

            代碼操作步驟如下:

            [tqg@localhost test]$ vi test.cpp


            #include <pthread.h>
            #include <signal.h>
            #include <stdio.h>
            #include <unistd.h>

            void signal_handler(int sig)
            {
                    printf("catch signal: %d,thread id = %u\n",sig,pthread_self());
                    pthread_exit(0);
            }

            void* thread_handler(void*arg)
            {
                    signal(SIGQUIT,signal_handler);

                    printf("thread arg = %s\n",(char*)arg);

                    sleep(10);
                    printf("in thread\n");

                    return (void*)0;
            }

            int main()
            {
                    char* pArg = "hello";
                    pthread_t tid;
                    pthread_create(&tid,NULL,thread_handler,pArg);

                    printf("main thread id = %u\n",pthread_self());
                    sleep(2);

                    printf("killing now\n");
                    pthread_kill(tid,SIGQUIT);

                    sleep(20);

                    printf("exit main now\n");

                    return 0;
            }
            ~
            ~
            ~
            ~
            "test.cpp" 42L, 648C written
            [tqg@localhost test]$ g++ -o test test.cpp -lpthread
            [tqg@localhost test]$ ./test
            main thread id = 3086875296
            thread arg = hello
            killing now
            catch signal: 3,thread id = 3086871472
            exit main now
            [tqg@localhost test]$

            可以看出,信號處理函數的執行是在要捕獲信號的子線程thread_handler的上下文中執行的。

            posted on 2009-01-15 11:39 true 閱讀(2402) 評論(6)  編輯 收藏 引用 所屬分類: C++基礎linux

            Feedback

            # re: linux下信號處理函數實現的一點理解[未登錄] 2009-01-15 12:59 steven
            昏倒,
            pthread_kill(tid,SIGQUIT);這是什么呀,這是向線程發信號,而不是向進程發。
            你要測試你需要的效果,請用kill(getpid(),SIGQUIT);  回復  更多評論
              

            # re: linux下信號處理函數實現的一點理解 2009-01-15 14:51 true
            沒太明白樓上的意識哦,我就是要向線程發送信號哦,“該線程先獲得cpu時間”的描述有誤解?確切些是進程中的線程獲得了cpu時間  回復  更多評論
              

            # re: linux下信號處理函數實現的一點理解 2009-01-24 06:53 ooo
            愣是沒看懂。。。lz你太有才了。。。

            你自己create了一個thread,然后發signal給剛建好的thread--到此為止一切正常

            但是你怎么得出結論,這是內核為你創建的一個線程?這分明是你自己剛創建的啊!

            你還是別學編程了。。。  回復  更多評論
              

            # re: linux下信號處理函數實現的一點理解 2009-02-02 16:05 true
            @ooo
            我表達的不夠清楚?“可以推斷為,當內核(?)捕獲到信號時,啟動了一個更高優先級的線程,該線程先獲得cpu時間,有他來執行信號處理函數。”,我是說的執行signal_handler的線程,不是thread_handler!  回復  更多評論
              

            # re: linux下信號處理函數實現的一點理解 2009-03-10 11:02 bert
            樓主啊,這是你自創的結論吧。。。
            在main函數的printf("main thread id = %u\n",pthread_self());
            下面添加一行:
            printf("child thread id = %u\n", tid);
            看看結果。
            再思考一下吧。。  回復  更多評論
              

            # re: linux下信號處理函數實現的一點理解 2009-03-10 11:24 true
            @bert
            @ooo
            今天又看了下文章,發現自己的錯誤如此低級,竟然誤拿main的id和子線程id進行了比較,謝謝2位,并向大家道歉!文章雖然修改  回復  更多評論
              

            精品免费久久久久国产一区| 久久久久久亚洲Av无码精品专口 | 久久国产影院| 2021国产精品午夜久久| 天天爽天天狠久久久综合麻豆| 99久久精品国产免看国产一区| 大蕉久久伊人中文字幕| 伊人久久亚洲综合影院| 久久精品国产福利国产秒| 合区精品久久久中文字幕一区 | 日日躁夜夜躁狠狠久久AV| 99久久国产综合精品网成人影院| 国产精品99久久久久久宅男小说| 久久精品www| 欧美午夜精品久久久久免费视| 欧美日韩精品久久久免费观看| 久久青青草原国产精品免费| 亚洲伊人久久综合影院| 99热成人精品免费久久| 国产精品久久永久免费| 人妻无码久久一区二区三区免费 | 亚洲色欲久久久综合网| 久久久久久久国产免费看| 777米奇久久最新地址| 久久综合综合久久综合| 亚洲国产精品无码久久久蜜芽| 久久久久亚洲AV综合波多野结衣| 99久久超碰中文字幕伊人| 色婷婷久久综合中文久久蜜桃av| 一级做a爰片久久毛片看看 | 国产69精品久久久久777| 伊人久久综合无码成人网| 久久久精品国产| 精品久久久一二三区| 午夜精品久久久久久影视riav| 久久久精品久久久久特色影视| 91久久国产视频| 伊人色综合九久久天天蜜桃| 香蕉久久久久久狠狠色| 人妻无码αv中文字幕久久| 国产精品一区二区久久国产|