Shangji Automation
- 1 year ago
- 0
- 0
OLE Automation — технология компании Microsoft , позволяющая обращаться к COM-объектам из интерпретаторов скриптовых языков, таких, как VBScript (на настоящий момент поддержка обращений к OA-объектам есть в Windows-версиях всех [ источник не указан 1206 дней ] популярных скриптовых языков).
Впервые появилась примерно в 1993 году как замена устаревшей возможности DDE_EXECUTE.
Среда программирования Visual Basic была практически полностью основана на OLE Automation, с такими типами данных, как String и Variant.
Объектами OLE Automation являются все элементы управления ActiveX (OCX-контролы). Свойства, методы и события этих компонент реализованы с помощью OLE Automation.
Также объектами OLE Automation являются многие популярные приложения, такие, как компоненты Microsoft Office . Это дает возможность запустить и управлять данным приложением (например, в Excel программно сформировать таблицу, заполнить в ней ячейки и сохранить в файл) из скрипта, написанного на скриптовом языке.
Также объектами OLE Automation являются все теги Dynamic HTML (при использовании Microsoft Trident или же Apple WebKit [нужно проверить] или Google Chrome [нужно проверить] ).
Также на этой технологии основана WMI (её слой, отвечающий за общение с клиентскими программами) и ряд административных утилит Windows, например, управление веб-сервером IIS .
Технология определяет те COM интерфейсы, через которые интерпретатор языка будет общаться с объектом.
Технология поддерживает:
Типы данных OLE Automation (могут использоваться в свойствах, методах и событиях):
Другие типы данных (структуры, указатели не на COM объект, другие представления массивов и строк) технологией не поддерживаются.
Также технология поддерживает type libraries — информацию о типах свойств/методов/аргументов, доступную во время выполнения (нечто вроде Reflection в .NET).
Обычно технология разрешает имена свойств и методов при исполнении, никак не проверяя их на этапе разбора, и возбуждая ошибку «объект не поддерживает свойство или метод» только при исполнении (позднее связывание). Однако, если у объекта есть type library, зарегистрированная на машине, то в некоторых средах разработки можно объявить его так, что имена будут проверяться на этапе разбора. В Visual Basic это делалось операторами Dim o As Object (только позднее связывание) или же Dim o As Excel.Application (раннее связывание, но требуется установка Excel на машину построения и добавление Excel к списку использованных в проекте компонент).
На уровне языков Си/Си++ вызов OLE Automation выглядит как вызов IDispatch::Invoke, куда передаются преобразованные в константы строковые имена метода/свойства/аргументов, и значения аргументов, преобразованных в типы OLE Automation. Это крайне неудобно и вызывает расходы производительности, потому у многих объектов реализованы т. н. дуальные интерфейсы — потомки IDispatch, реализующие и Invoke (используется скриптами и в случае объявления As Object), ровно ту же функциональность через обычные COM методы (используется C++ и теми интерпретаторами, что понимают дуальные интерфейсы, как Visual Basic). При этом сохраняется ограничение на типы данных, приведенное выше. Библиотека ATL содержит в себе фреймворк поддержки дуальных интерфейсов.
Компилятор Microsoft C++ поддерживает директиву #import — включение type library (.tlb или же исполняемого файла, в который она вшита). При этом из исходного файла генерируются автоматически заголовки Си++, использующие средства comdef.h (смарт-пойнтеры на COM объекты и т. д.).
Цикл разработки объектов:
Цикл построения объектов: