亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 2613 | 回復: 3
打印 上一主題 下一主題

關(guān)于hashlimit模塊不解的地方 [復制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2011-03-25 18:36 |只看該作者 |倒序瀏覽
看了九賤兄寫的hashlimit模塊的理解,大有收獲,但還是有一些細節(jié)沒有搞清楚,代碼如下:
2.6.35/net/netfilter/xt_hashlimit.c中的static int htable_create()函數(shù)中:
{
                .....
        /* FIXME: don't use vmalloc() here or anywhere else -HW */
        hinfo = vmalloc(sizeof(struct xt_hashlimit_htable) + sizeof(struct list_head) * size);
       
        if (hinfo == NULL)
                return -ENOMEM;
        minfo->hinfo = hinfo;

        /* copy match config into hashtable config */
        memcpy(&hinfo->cfg, &minfo->cfg, sizeof(hinfo->cfg));
       
        hinfo->cfg.size = size;
       
        if (hinfo->cfg.max == 0)
                hinfo->cfg.max = 8 * hinfo->cfg.size;
        else if (hinfo->cfg.max < hinfo->cfg.size)
                hinfo->cfg.max = hinfo->cfg.size;

        for (i = 0; i < hinfo->cfg.size; i++)
                INIT_HLIST_HEAD(&hinfo->hash[i]);
                .....
}

上面代碼中是用sizeof(struct list_head) 類型來申請的空間,而后面卻是用哈希表頭的初始化INIT_HLIST_HEAD(&hinfo->hash[i])函數(shù)來進行初始化的,
這樣就相當于多申請了一倍的空間,不知為什么?用8字節(jié)的類型來申請的空間,卻用4字節(jié)的類型來進行初始化,不理解為什么?請大家?guī)臀铱纯催@兒是怎么一
回事?

論壇徽章:
0
2 [報告]
發(fā)表于 2011-03-28 11:55 |只看該作者
喜歡樓主的頭像。

剛才粗略地看了一下,的確暫時沒有找到其它合理解釋——是不是作者分配的時候少打了一個h???寫封信問一下他嘛。

論壇徽章:
36
IT運維版塊每日發(fā)帖之星
日期:2016-04-10 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-04-16 06:20:0015-16賽季CBA聯(lián)賽之廣東
日期:2016-04-16 19:59:32IT運維版塊每日發(fā)帖之星
日期:2016-04-18 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-04-19 06:20:00每日論壇發(fā)貼之星
日期:2016-04-19 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-04-25 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-05-06 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-05-08 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-05-13 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-05-28 06:20:00每日論壇發(fā)貼之星
日期:2016-05-28 06:20:00
3 [報告]
發(fā)表于 2011-03-28 12:24 |只看該作者
我看 2.6.37 的代碼中也是這樣。

論壇徽章:
0
4 [報告]
發(fā)表于 2012-02-03 01:28 |只看該作者
  1. struct list_head {
  2. struct list_head *next, *prev;
  3. };

  4. struct hlist_head {
  5. struct hlist_node *first;
  6. };

  7. struct hlist_node {
  8. struct hlist_node *next, **pprev;
  9. };
復制代碼
http://blog.chinaunix.net/u/12592/showart.php?id=451619


您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP