Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.07.10;
Скачать: CL | DM;

Вниз

Работа с Excel через OLE   Найти похожие ветки 

 
Koloto   (2003-06-27 09:14) [0]

Приложение (правда, на Билдере 5.0) создает объект Excelя и работает с ним. После конца работы (даже после закрытия приложения) Ексель остается открытым, чтоб юзер мог посмотреть, что там прога натворила.
Приложение многопоточное, объект Екселя создается через CreateOleObject, вся работа с ним ведется через Variant путем вызова OLE-шных функций и свойств, все внутри одного потока.
Пока Ексель остается открытым, все работает отлично. Но как только юзер закрывает его (независимо от того, открыто еще приложение или нет), вылетает ошибка:

"Инструкция по адресу ... обратилась к памяти по адресу ... Память не может быть "read" "

Не подскажите, в чем может быть проблема?


 
kudatsky   (2003-06-27 09:24) [1]

Если у тебя Excel 97, инстолируй Excel 97 SR2,
а лучше 2000


 
andrey_pst ©   (2003-06-27 10:49) [2]

ссылки на все объекты Excel"я убиваешь ?
например,
xlsApp := UnAssigned;


 
Koloto   (2003-06-27 12:05) [3]

Спасибо всем.
Проблема решилась путем использования OleInitialize / OleUninitialize. Оказывается при работе с OLE в многопоточном приложении надо вызывать эти функции.
Интересно, что в борландовском хелпе (по крайней мере к Билдеру 5.0) ничего про это не сказано.



Страницы: 1 вся ветка

Текущий архив: 2003.07.10;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.015 c
3-31151
Alexei Petrakov
2003-06-18 16:58
2003.07.10
Raiserror не генерит исключение


1-31343
INTAARI
2003-06-27 13:24
2003.07.10
Не поймать исключение


8-31363
reticon
2003-03-15 18:04
2003.07.10
вывод текста


14-31401
VEG
2003-06-25 13:09
2003.07.10
Нити в Си


1-31208
LuckyMan
2003-06-27 19:04
2003.07.10
Алгоритм поиска файлов по маске