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

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            如何讓errno多線程/進程安全

            Posted on 2009-05-08 16:12 Prayer 閱讀(865) 評論(0)  編輯 收藏 引用 所屬分類: LINUX/UNIX/AIX

             linux或者unix環境中,errno是一個十分重要的部分。在調用的函數出現問題的時候,我們可以通過errno的值來確定出錯的原因,這就會 涉及到一個問題,那就是如何保證errno在多線程或者進程中安全?我們希望在多線程或者進程中,每個線程或者進程都擁有自己獨立和唯一的一個 errno,這樣就能夠保證不會有競爭條件的出現。一般而言,編譯器會自動保證errno的安全性,但是為了妥善期間,我們希望在寫makefile的時 候把_LIBC_REENTRANT宏定義,比如我們在檢查<bits/errno.h>文件中發現如下的定義:
            # ifndef __ASSEMBLER__
            /* Function to get address of global `errno' variable.  */
            extern int *__errno_location (void) __THROW __attribute__ ((__const__));

            #  if !defined _LIBC || defined _LIBC_REENTRANT
            /* When using threads, errno is a per-thread value.  */
            #   define errno (*__errno_location ())
            #  endif
            # endif /* !__ASSEMBLER__ */
            #endif /* _ERRNO_H */
            也就是說,在沒有定義__LIBC或者定義_LIBC_REENTRANT的時候,errno是多線程/進程安全的。
            一般而言, __ASSEMBLER__, _LIBC_LIBC_REENTRANT都不會被編譯器定義,但是如果我們定義_LIBC_REENTRANT一次又何妨那? <!--[if !vml]--><!--[endif]-->
            為了檢測一下你編譯器是否定義上述變量,不妨使用下面一個簡單程序。
            #include <stdio.h>
            #include <errno.h>

            int main( void )
            {
            #ifndef __ASSEMBLER__
                    printf( "Undefine __ASSEMBLER__\n" );
            #else
                    printf( "define __ASSEMBLER__\n" );
            #endif

            #ifndef __LIBC
                    printf( "Undefine __LIBC\n" );
            #else
                    printf( "define __LIBC\n" );
            #endif

            #ifndef _LIBC_REENTRANT
                    printf( "Undefine _LIBC_REENTRANT\n" );
            #else
                    printf( "define _LIBC_REENTRANT\n" );
            #endif

                    return 0;
            }
            希望讀者在進行移植的時候,讀一下相關的unix版本的<bits/errno.h>文件,來確定應該定義什么宏。不同的unix版本可能存在著一些小的差別!
            <!--[if !supportLineBreakNewLine]-->
            <!--[endif]-->



             
            我要這里補充一下,要線程安全,我們應該定義_REENTRANT宏。請參考features.h文件

            在windows中,我們需要定義_MT來勢error具有多線程安全性!

            http://blog.csdn.net/hello_wyq/archive/2006/08/01/1006216.aspx

            狠狠色伊人久久精品综合网 | 中文成人无码精品久久久不卡| 久久精品国产亚洲欧美| 狠狠精品久久久无码中文字幕 | 热re99久久6国产精品免费| 亚洲国产精品一区二区久久hs| 久久无码人妻一区二区三区 | 久久笫一福利免费导航| 亚洲精品乱码久久久久66| 人人狠狠综合久久亚洲88| 亚洲国产成人精品无码久久久久久综合| 伊人久久无码精品中文字幕| 狠狠色丁香久久婷婷综| 久久天天躁狠狠躁夜夜2020一| 麻豆精品久久久一区二区| 麻豆av久久av盛宴av| 久久国产精品二国产精品| 国产精品久久久久久吹潮| 亚洲欧美另类日本久久国产真实乱对白| 国内精品久久久久影院一蜜桃| 性欧美大战久久久久久久| 国产精品伊人久久伊人电影| 亚洲日本va中文字幕久久| 深夜久久AAAAA级毛片免费看 | 亚洲精品NV久久久久久久久久| 国内精品伊人久久久久| 亚洲国产精品无码久久久蜜芽| 久久露脸国产精品| 国产成人香蕉久久久久| 久久精品国产影库免费看| 精品国产一区二区三区久久久狼| 久久丫忘忧草产品| 色8激情欧美成人久久综合电| 国产精品免费久久久久电影网| 久久久久成人精品无码中文字幕 | 国产毛片欧美毛片久久久 | 91久久精品无码一区二区毛片| 亚洲成色www久久网站夜月| 久久人人添人人爽添人人片牛牛| 伊人色综合久久天天人守人婷| 亚洲国产精品成人久久蜜臀 |