SetupDiGetClassDevs

函数定义
HDEVINFO
SetupDiGetClassDevs(
const GUID* ClassGuid,
PCTSTR Enumerator,
HWND hwndParent,
DWORD Flags
);
输入参数:
PGUID ClassGuid
在创建设备列表的时候提供一个指向GUID的 指针。如果设定了标志DIGCF_ALLCLASSES,则这个参数可以忽略,且列表结果中包括所有已经安装的设备类别。
PCTSTR Enumerator
提供包含设备实例的枚举注册表分支下的键名,可以通过它获取设备信息。如果这个参数没有指定,则要从整个枚举树中获取所有设备实例的设备信息。
HWND hwndParent
提供顶级窗口的句柄,所有 用户接口可以使用它来与成员联系。
DWORD Flags
提供在设备信息结构中使用的控制选项。可以是以下数值:
DIGCF_PRESENT            - 只返回当前存在的设备。
DIGCF_ALLCLASSES      - 返回所有已安装的设备。如果这个标志设置了,ClassGuid参数将被忽略。
DIGCF_PROFILE             - 只返回当前 硬件配置文件中的设备。
DIGCF_DEVICEINTERFACE      - 返回所有支持的设备。
DIGCF_DEFAULT            - 只返回与系统默认设备相关的设备。
HDEVINFO
如果函数运行成功,返回设备信息结构的句柄,该结构包含与指定参数匹配的所有已安装设备。如果失败,则返回INVALID_HANDLE_VALUE。调用GetLastError可以获得更多 错误信息
使用此函数,需要包含头文件setupapi.h。
此外,在project setting中的link页面需要添加setupapi.lib。
在setupapi.h中有如下定义:
typedef PVOID HDEVINFO;

你可能感兴趣的:(API)