|
|
|
ошибка в потоке....
|
|||
|---|---|---|---|
|
#18+
Есть такая функция Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. и из программы она вызывается в нескольких местах Код: plaintext 1. 2. 3. 4. 5. и еще из потока в этом же модуле Код: plaintext 1. 2. 3. 4. 5. Сам програмный модуль может работать и как служба, и как обычное консольное приложение. НО. В обычном консолном приложении все отрабатывается отлично и без ошибок, а при запуске в виде службы функция LogReport вызванная из OnProgramStart() (т.е. не из потока) работает отлично, а при вызове из ThRunJob() (из потока) вызывает ран-тайм ошибку. Что это может быть? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 17.04.2006, 14:43 |
|
||
|
ошибка в потоке....
|
|||
|---|---|---|---|
|
#18+
pXMLLogDoc Описан глобально как IXMLDOMDocument * pXMLLogDoc; ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 17.04.2006, 14:48 |
|
||
|
ошибка в потоке....
|
|||
|---|---|---|---|
|
#18+
дед МакарЕсть такая функция Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. и из программы она вызывается в нескольких местах Код: plaintext 1. 2. 3. 4. 5. и еще из потока в этом же модуле Код: plaintext 1. 2. 3. 4. 5. Сам програмный модуль может работать и как служба, и как обычное консольное приложение. НО. В обычном консолном приложении все отрабатывается отлично и без ошибок, а при запуске в виде службы функция LogReport вызванная из OnProgramStart() (т.е. не из потока) работает отлично, а при вызове из ThRunJob() (из потока) вызывает ран-тайм ошибку. Что это может быть? Могу предположить, что дело здесь в отсутствии синхронизации при записи в файл. Т.е. где-то происходит наложение попыток записи в одно и то же место файла. Используйте критические секции... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 17.04.2006, 15:13 |
|
||
|
ошибка в потоке....
|
|||
|---|---|---|---|
|
#18+
Станислав C.Используйте критические секции... Использую. void LogReport(CString type, CString value, int level) { /* Функция которая пишет в логфайл на локальном диске. */ crtSecLR.Lock(); ^^^^^^^^^ ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 17.04.2006, 16:11 |
|
||
|
|

start [/forum/topic.php?fid=57&gotonew=1&tid=2031501]: |
0ms |
get settings: |
10ms |
get forum list: |
19ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
178ms |
get topic data: |
10ms |
get first new msg: |
6ms |
get forum data: |
2ms |
get page messages: |
56ms |
get tp. blocked users: |
2ms |
| others: | 250ms |
| total: | 539ms |

| 0 / 0 |
