• <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++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            如何讓errno多線程/進(jìn)程安全

            Posted on 2009-05-08 16:12 Prayer 閱讀(870) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): LINUX/UNIX/AIX

             linux或者unix環(huán)境中,errno是一個(gè)十分重要的部分。在調(diào)用的函數(shù)出現(xiàn)問(wèn)題的時(shí)候,我們可以通過(guò)errno的值來(lái)確定出錯(cuò)的原因,這就會(huì) 涉及到一個(gè)問(wèn)題,那就是如何保證errno在多線程或者進(jìn)程中安全?我們希望在多線程或者進(jìn)程中,每個(gè)線程或者進(jìn)程都擁有自己獨(dú)立和唯一的一個(gè) errno,這樣就能夠保證不會(huì)有競(jìng)爭(zhēng)條件的出現(xiàn)。一般而言,編譯器會(huì)自動(dòng)保證errno的安全性,但是為了妥善期間,我們希望在寫(xiě)makefile的時(shí) 候把_LIBC_REENTRANT宏定義,比如我們?cè)跈z查<bits/errno.h>文件中發(fā)現(xiàn)如下的定義:
            # 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 */
            也就是說(shuō),在沒(méi)有定義__LIBC或者定義_LIBC_REENTRANT的時(shí)候,errno是多線程/進(jìn)程安全的。
            一般而言, __ASSEMBLER__, _LIBC_LIBC_REENTRANT都不會(huì)被編譯器定義,但是如果我們定義_LIBC_REENTRANT一次又何妨那? <!--[if !vml]--><!--[endif]-->
            為了檢測(cè)一下你編譯器是否定義上述變量,不妨使用下面一個(gè)簡(jiǎn)單程序。
            #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;
            }
            希望讀者在進(jìn)行移植的時(shí)候,讀一下相關(guān)的unix版本的<bits/errno.h>文件,來(lái)確定應(yīng)該定義什么宏。不同的unix版本可能存在著一些小的差別!
            <!--[if !supportLineBreakNewLine]-->
            <!--[endif]-->



             
            我要這里補(bǔ)充一下,要線程安全,我們應(yīng)該定義_REENTRANT宏。請(qǐng)參考features.h文件

            在windows中,我們需要定義_MT來(lái)勢(shì)error具有多線程安全性!

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

            日本久久久久亚洲中字幕| 狠狠人妻久久久久久综合| 久久久久久精品免费免费自慰| 久久强奷乱码老熟女网站| 久久久久亚洲AV无码专区首JN | 久久99精品国产99久久6| 久久久久久亚洲精品不卡| 久久人人爽爽爽人久久久| 国产精品gz久久久| 亚洲人成网亚洲欧洲无码久久| 996久久国产精品线观看| 亚洲人成无码网站久久99热国产| 久久精品国产亚洲av麻豆色欲 | 久久人妻少妇嫩草AV蜜桃| 久久亚洲美女精品国产精品| 久久亚洲中文字幕精品一区四| 欧洲人妻丰满av无码久久不卡| 久久综合日本熟妇| 国产精品美女久久久久AV福利| 无码国产69精品久久久久网站 | 国产精品久久久久天天影视| 狠狠色丁香久久婷婷综合图片| 日韩精品久久久久久| 久久免费的精品国产V∧| 久久无码国产专区精品| 亚洲国产精品狼友中文久久久| 青青国产成人久久91网| 久久精品国产69国产精品亚洲 | 久久婷婷人人澡人人| 国产精品99久久久久久宅男| 久久香蕉国产线看观看99| 7777久久亚洲中文字幕| 久久精品中文字幕久久| 国内精品久久久久久野外| 91精品国产91久久久久福利| .精品久久久麻豆国产精品| 久久精品亚洲日本波多野结衣 | 国内精品久久久久影院薰衣草| 女人高潮久久久叫人喷水| 久久综合久久性久99毛片| 伊人久久亚洲综合影院|