国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

linux_Ultra的個(gè)人空間 http://www.qingdxww.cn/space-uid-2909.html [收藏] [復(fù)制] [RSS]

博客

device iterator

已有 3079 次閱讀2010-4-18 17:44 |

還是得用Google的.com啊。
//--------------------drivers/base/Bus.c----------------------------------
....
.....
/**
 * bus_for_each_dev - device iterator.
 * @bus: bus type.
 * @start: device to start iterating from.
 * @data: data for the callback.
 * @fn: function to be called for each device.
 *
 * Iterate over @bus's list of devices, and call @fn for each,
 * passing it @data. If @start is not NULL, we use that device to
 * begin iterating from.
 *
 * We check the return of @fn each time. If it returns anything
 * other than 0, we break out and return that value.
 *
 * NOTE: The device that returns a non-zero value is not retained
 * in any way, nor is its refcount incremented. If the caller needs
 * to retain this data, it should do so, and increment the reference
 * count in the supplied callback.
 */
int bus_for_each_dev(struct bus_type *bus, struct device *start,
             void *data, int (*fn)(struct device *, void *))
{
    struct klist_iter i;
    struct device *dev;
    int error = 0;

    if (!bus)
        return -EINVAL;

    klist_iter_init_node(&bus->p->klist_devices, &i,
                 (start ? &start->p->knode_bus : NULL));
    while ((dev = next_device(&i)) && !error)
        error = fn(dev, data);
    klist_iter_exit(&i);
    return error;
}
-----------------------------------------------------------------------------------------------------
C/Iterators
The problem

Suppose we have an abstract data type that represents some sort of container, such as a list or dictionary. We'd like to be able to do something to every element of the container; say, count them up. How can we write operations on the abstract data type to allow this, without exposing the implementation?

To make the problem more concrete, let's suppose we have an abstract data type that represents the set of all non-negative numbers less than some fixed bound. The core of its interface might look like this:

nums.h

function isnumbered(obj) { return obj.childNodes.length && obj.firstChild.childNodes.length && obj.firstChild.firstChild.className == 'LineNumber'; } function nformat(num,chrs,add) { var nlen = Math.max(0,chrs-(''+num).length), res = ''; while (nlen>0) { res += ' '; nlen-- } return res+num+add; } function addnumber(did, nstart, nstep) { var c = document.getElementById(did), l = c.firstChild, n = 1; if (!isnumbered(c)) if (typeof nstart == 'undefined') nstart = 1; if (typeof nstep == 'undefined') nstep = 1; n = nstart; while (l != null) { if (l.tagName == 'SPAN') { var s = document.createElement('SPAN'); s.className = 'LineNumber' s.appendChild(document.createTextNode(nformat(n,4,' '))); n += nstep; if (l.childNodes.length)

路過(guò)

雞蛋

鮮花

握手

雷人

發(fā)表評(píng)論 評(píng)論 (1 個(gè)評(píng)論)

facelist

您需要登錄后才可以評(píng)論 登錄 | 立即注冊(cè)

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號(hào) | 京公網(wǎng)安備11010502021702
返回頂部
主站蜘蛛池模板: 久久作爱视频 | 国产人成在线视频 | 2021国产精品自在拍在线播放 | 九九九热视频 | 精品视频久久久久 | 国产欧美日本在线 | 国产精品va欧美精品 | 国产偷国产偷亚洲高清在线 | 一级黄色a | 日韩手机在线免费视频 | 欧美日韩中文国产一区二区三区 | 中文字幕精品一区二区三区视频 | 亚洲国产天堂久久综合226 | 日韩大片在线播放 | 影音先锋色偷偷米奇四色 | 国产精品高清一区二区三区 | 五月天天爱| 岬奈一区二区中文字幕 | 四虎影院紧急入口 | 日本国产成人精品视频 | 亚洲黄视频在线观看 | 羞羞视频免费网站日本 | 激情影院在线视频永久观看 | 91免费网| 日本免费的一级v一片 | 久久婷婷色 | 99r在线观看 | 99午夜| 日韩欧美精品在线 | 国产亚洲精品xxx | 日本不卡视频在线视频观看 | jizz日本老师 | 污视频网站在线观看免费 | 女性爽爽影院免费观看麻豆 | 亚洲高清美女一区二区三区 | 色人阁导航 | 国产精品视频久久久久 | 兔女郎穿着丝袜被啪啪 | 久久99热精品免费观看无卡顿 | 国产精品二区在线 | 国产精品福利片免费看 |