![]() |
Модераторы: feodorv, GremlinProg, xvr, Fixin |
![]() ![]() ![]() |
|
heavix |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 60 Регистрация: 10.8.2007 Репутация: нет Всего: нет |
Приветствую Всех)
Уважаемые форумчане, кто-нибудь использовал функцию ReadEventLog? Возникла задача читать записи из системного лога... Почитал МСДН... нашел апишки: OpenEventLog и ReadEventLog набросал тестовый примерчик, и застрял... Собственно проблемка: читаю в цикле все записи с System ивент лога, замечательно читается, только вот не весь лог! Впихнул счетчик... читает около 500 записей, потом коректно завершается и все... нигде по ошибке не вылетает! Виндовый Event Viewer говорит что у мну записей в даном логе больше 2000! Может кто сталкивался, есть там какие-нить особенности работы с данной функцией, или еще где торможу! Заранее благодарен всем откликнувшимся! делаю так:
|
|||
|
||||
Andrey44 |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1501 Регистрация: 4.12.2006 Где: На работе Репутация: 8 Всего: 26 |
Пример из МСДН -------------------- ????? ??, ??????? ?????. ![]() |
|||
|
||||
heavix |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 60 Регистрация: 10.8.2007 Репутация: нет Всего: нет |
Огромное спасибо))) Но уже сам разобрался - спас рихтер)
хотя не совсем понял почему именно так не работало, но избавившись от переменной dwBytesToRead и сделав вызов чтения следующим образом:
все замечательно начало работать))) |
|||
|
||||
Andrey44 |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1501 Регистрация: 4.12.2006 Где: На работе Репутация: 8 Всего: 26 |
dwBytesNeed - как я понял это размер бафера для чтения, а вы передавали туда 1
-------------------- ????? ??, ??????? ?????. ![]() |
|||
|
||||
heavix |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 60 Регистрация: 10.8.2007 Репутация: нет Всего: нет |
только dwBytesToRead )) Да, передавал )) но это нормальная ситуация для Апишек, когда вызов происходит в 2 этапа: при первом передается единичка (или вообще 0), получаем в dwBytesNeed размер для буфера, выделяем под него место и повторно перечитываем)) Даже если бы функция делала смещение на 1 запись при каждом чтении (а что не так) то я читал бы количество записей меньшее реального ровно в половину))) - что тоже не наблюдалось. По сему пока данное поведение сией апишки для меня мистика) но главное что задача вообще решена) Это сообщение отредактировал(а) heavix - 5.12.2011, 19:37 |
|||
|
||||
![]() ![]() ![]() |
Правила форума "C/C++: Системное программирование и WinAPI" | |
|
На данный раздел распространяются Правила форума и Правила раздела С++:Общие вопросы . Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Chipset, Step, Fixin, GremlinProg, xvr. feodorv. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | C/C++: Системное программирование и WinAPI | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |