如何在winevt.h Windows C++API中的EvtSubscribe中使用Context参数
How to use Context argument in EvtSubscribe in winevt.h Windows C++ API
我正在尝试使用Windows C++API中提供的winevt.h头中的EvtSubscribe函数。
目前,我对EvtSubscibe的呼叫如下:
EvtSubscribeData data;
hResults = EvtSubscribe(
NULL, NULL, L"Security", L"Event/System[EventID=4624]", NULL, reinterpret_cast<void *>(&data), (EVT_SUBSCRIBE_CALLBACK)callback, EvtSubscribeStartAtOldestRecord
);
EvtSubscribeData是一个类,它有一个名为subscribe
的函数,我的回调函数如下所示:
DWORD callback(EVT_SUBSCRIBE_NOTIFY_ACTION Action, PVOID UserContext,EVT_HANDLE Event) {
return reinterpret_cast<EvtSubscribeData *>(UserContext)->subscribe(Action, Event);
}
正如您所知,我正在使用Context参数,该参数允许我使用回调中返回的数据来填充EvtSubscribeData类成员变量。
唯一的问题是返回一个数据点,然后程序停止。EVT_SUBSCRIBE_CALLBACK函数说subscribe
函数正在阻塞,所以我的第一个想法是callback
永远不会返回,但调试后,callback
返回0,这是从EvtSubscribeData::subscribe
正确返回的。
当我删除Context参数并使用EvtSubscribeData::subscribe
作为函数而不是成员函数时(如这里所示的示例),打印数百个事件时,一切都会正常工作。
一个简单的EvtSubscribeData函数:
class EvtSubscribeData {
public:
EvtSubscribeData() {}
DWORD WINAPI subscribe(EVT_SUBSCRIBE_NOTIFY_ACTION action, EVT_HANDLE event) {
auto status = ERROR_SUCCESS;
switch (action) {
case EvtSubscribeActionError:
if (ERROR_EVT_QUERY_RESULT_STALE == (DWORD)event) {
std::cout << "event records are missing" << std::endl;
} else {
std::cout << "win32 Error" << (DWORD)event << std::endl;
}
break;
case EvtSubscribeActionDeliver:
status = PrintEvent(event);
break;
}
return status;
}
};
唯一的问题是返回一个数据点,然后程序停止。
将WINAPI添加到回调函数中,看看它是否有效。如果没有WINAPI关键字,它会导致您的"访问违规读取"异常(而不是"订阅功能被阻止"。)
回调如下:
DWORD WINAPI callback(EVT_SUBSCRIBE_NOTIFY_ACTION Action, PVOID UserContext, EVT_HANDLE Event) {
return reinterpret_cast<EvtSubscribeData *>(UserContext)->subscribe(Action, Event);
}
它对我有用。
更多参考:"主要功能中的"WINAPI"是什么意思?">
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何在winevt.h Windows C++API中的EvtSubscribe中使用Context参数