• <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++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            linux-ftok函數

            Posted on 2009-06-30 12:07 Prayer 閱讀(407) 評論(0)  編輯 收藏 引用 所屬分類: LINUX/UNIX/AIX

            系統建立IPC通訊(如消息隊列、共享內存時)必須指定一個ID值。通常情況下,該id值通過ftok函數得到。
            ftok原型如下:
            key_t ftok( char * fname, int id )

            fname就時你指定的文件名(該文件必須是存在而且可以訪問的),id是子序號,雖然為int,但是只有8個比特被使用。

               在一般的UNIX實現中,是將文件的索引節點號取出,前面加上子序號得到key_t的返回值。如指定文件的索引節點號為65538,換算成16進制為 0x010002,而你指定的ID值為38,換算成16進制為0x26,則最后的key_t返回值為0x26010002。
            查詢文件索引節點號的方法是: ls -i
               當刪除重建文件后,索引節點號由操作系統根據當時文件系統的使用情況分配,因此與原來不同,所以得到的索引節點號也不同。
               如果要確保key_t值不變,要目確保ftok的文件不被刪除,要么不用ftok,指定一個固定的key_t值,比如:

            #define IPCKEY 0x111

            char path[256];

            sprintf( path, "%s/etc/config.ini", (char*)getenv("HOME") );
            msgid=ftok( path, IPCKEY );[/code]

            同一段程序,用于保證兩個不同用戶下的兩組相同程序獲得互不干擾的IPC鍵值。
            由于etc/config.ini(假定)為應用系統的關鍵配置文件,因此不存在被輕易刪除的問題——即使被刪,也會很快被發現并重建(此時應用系統也將被重起)。
            ftok()的設計目的也在于此。


            国产精品美女久久久久网| 无码人妻精品一区二区三区久久| www.久久99| 99久久无码一区人妻| 亚洲国产小视频精品久久久三级| 国产69精品久久久久久人妻精品| 无码超乳爆乳中文字幕久久| 色综合色天天久久婷婷基地| 久久精品国产99久久香蕉| 97精品伊人久久久大香线蕉| 国产精品久久久福利| 精品久久人人爽天天玩人人妻| 国产激情久久久久久熟女老人| 秋霞久久国产精品电影院| 国产精品久久久久蜜芽| aaa级精品久久久国产片| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区| 久久精品国产亚洲AV无码娇色 | 伊人色综合久久天天| 欧美久久久久久| 51久久夜色精品国产| 亚洲狠狠婷婷综合久久久久| 国产免费久久精品99久久| 久久精品无码专区免费青青| 伊人久久一区二区三区无码| 久久青草国产精品一区| 伊人久久大香线蕉综合5g| 国产精品无码久久四虎| 97热久久免费频精品99| 久久中文字幕精品| 色综合久久天天综线观看| 青青草原综合久久大伊人精品| 色妞色综合久久夜夜| 久久午夜福利无码1000合集| 久久久高清免费视频| 一级做a爰片久久毛片看看| 日本亚洲色大成网站WWW久久| 久久国产成人亚洲精品影院| 伊人色综合久久天天| 久久久久亚洲?V成人无码| 精品综合久久久久久88小说|