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

Вниз

Интересный факт...   Найти похожие ветки 

 
kull   (2003-05-29 15:43) [0]

Вот написал ActiveX library, в которой есть интерфейс для преобразования документа Word в свой формат...

Вызываю метод ConvertDocument из ActiveX библиотеки двумя способами:

1. из макроса word-a

Public Sub RunConvert()
Dim aa As Object
Set aa = CreateObject("MyConvertors.MyConvertor")
aa.ConvertDocument(ActiveDocument)
End Sub


2. из Дельфовского приложения:
procedure TTestCase_MyConvertors.TestMyConvertion;
var
itfMyConvertor: IMyConvertor;
itfWordApplication: Word2000._Application;
itfDocument: Word2000._Document;
vrntFileName: OleVariant;
begin
itfMyConvertor := CoMyConvertor.Create;
itfWordApplication := CoWordApplication.Create;
try
vrntFileName := "c:\testconvertor.doc";
itfDocument := itfWordApplication.Documents.AddOld(vrntFileName, EmptyParam);

itfMyConvertor.ConvertDocument(itfDocument);
finally
itfWordApplication.Quit(EmptyParam, EmptyParam, EmptyParam);
end;
finally
CoUninitialize;
end;
end;


так вот в варианте 1 метод ConvertDocument работает 0.5 сек, а в варианте 2 - 12 сек.

Откуда такая разница? Я понимаю, конечно что в (1) идет обмен данными внутри одного процесса, а в (2) между процессами, но неужели скорость этого обмена отличается более чем в 20 раз?

Как это объяснить?


 
Skier   (2003-05-29 15:45) [1]


> Как это объяснить?

Ты сам себе уже всё объяснил... :)


 
Sandman25   (2003-05-29 15:54) [2]

Я думаю, бОльшая часть времени уходит на загрузку Ворда.


 
kull   (2003-05-29 16:10) [3]


> Sandman25 © (29.05.03 15:54)

Нет, в том то и дело, что я говорю именно о времени выполнения метода ConvertDocument. приего выполнении появляется окно с Progress bar-ом. И разницу видно невооруженным глазом...


> Skier © (29.05.03 15:45)

Ну неужели такая разница? Больше чем на порядок.


 
DiamondShark   (2003-05-29 16:48) [4]

Да, такая разница.
Представте себе, пусть приблизительно, сколько нужно действий, чтобы передать вызовы между процессами.


 
kull   (2003-05-29 17:39) [5]


> DiamondShark © (29.05.03 16:48)

То есть, я понимаю так, что действий этих в 20 раз больше?!
Так что ли?



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

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

Наверх




Память: 0.45 MB
Время: 0.006 c
14-50480
Salvator
2003-05-30 11:38
2003.06.16
Поиск Форумов


1-50385
Tornado
2003-06-04 13:19
2003.06.16
Форма


1-50318
Scorpx
2003-06-03 10:34
2003.06.16
Каталог...


8-50401
Serge Pik
2003-03-01 13:58
2003.06.16
Поддержка Surfaсe, teeChartPro


14-50445
jack128
2003-05-28 22:04
2003.06.16
IDE





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский