вторник, 27 января 2015 г.

Компилируем под iOS быстрее с AIR 4

Введение


Приложения AIR для iOS могут быть упакованы несколькими способами, при помощи опции Fast packaging (интерпретируемый режим) или Standard (скомпилированный режим) упаковки. Интерпретируемый режим, который прежде всего используется для отладки, быстрее компилируется, чем скомпилированный режим. Хотя большая часть разработки и тестирования могут быть выполнены, используя интерпретируемый режим, производительность во время выполнения хуже чем при использовании скомпилированного режима. Разработчики, публикующие приложения в AppStore, используют скомпилированный режим для лучшей производительности.
Однако длительное время требуемое для упаковки в скомпилированном режиме, не вызывает позитвных эмоций.

AIR предоставляет перепроектировочный (re-designed) скомпилированный режим упаковки, который стремится значительно уменьшить время упаковки с сохранением такой же производительности во время выполнения. Бета-версия перепроектированного компилятора в настоящее время доступна всем разработчикам. ( речь в данном случае идет о AIR4, он же AIR 12 )

Обзор режима компиляции

При упаковке приложения AIR для iOS:

SWF файл разработчика анализируется, чтобы извлечь блоки байт-кода (Action Script Bytecode) (abc).
После анализа содержания abc, и используя API LLVM каждая функция AS переводится в соответствующую нативную функцию.
С помощью генератора кода LLVM, генерируется объектный файл для целевой платформы.
Создается исполняемый файл, линковка объектных файлов и библиотек AIR Runtime.

Платформа iOS не поддерживает динамически загружающийся исполняемый код. Это ограничение, однако позволяет упаковщику AIR использовать методы оптимизации для увеличения производительности во время выполнения. Эта оптимизация возможна, потому что весь код доступен во время компиляции. Посмотрите рисунок 1 для иллюстрации упаковки приложения AIR в скомпилированном режиме.

image

Рис. 1

Устаревший компилятор v/s Новый компилятор

Новый компилятор создан поверх виртуальной машины Action Script. Далее — сравнение перепроектированного компилятора и устаревшего компилятора.


Старый компиляторНовый компилятор
Разработанный с использованием Java и взаимодействовал с LLVM используя JNI, таким образом плохо влияя на производительность.Разработанный с использованием C++ и большая часть его кода взята из виртуальной машиной.
Генерирует вызов функции для каждого кода операций (abc opcode).Преобразовывает код операции (abc opcode) в SSA на базе IR (промежуточное представление) и генерирует оптимизированный IR.
Компилирует встроенную библиотеку каждый раз, когда приложение упаковано.Выполняет инкрементную компиляцию, что означает, что встроенная библиотека скомпилирована только один раз и поставляется с SDK AIR.


Посмотрите рисунки 2 и 3 для иллюстрации изменений в перепроектированном компиляторе.

image
Рис. 2

image
Рис. 3

Использование нового режима упаковки


В AIR 14 Вы можете использовать любой из следующих методов, чтобы начать использовать новый компилятор.

Командная строка

Чтобы начать использовать новый компилятор для упаковки вашего IPA, используйте параметр –useLegacyAOT и установите его значение в no:

<AIR SDK>/bin/adt -package -target ipa-app-store -useLegacyAOT no -provisioning-profile abc.mobileprovision -storetype pkcs12 -keystore abc.p12 HelloWorld.ipa HelloWorld-app.xml HelloWorld.swf


Flash Builder

Чтобы использовать эту функцию в Flash Builder 4.7:

1. Нажмите Project >Debug/Run > Debug Configurations/Run Configurations.

2. Нажмите Customize Launch в диалоговом окне Debug Configurations.
Окно Customize Launch Parameters выводит на экран все параметры, передаваемые в ADT вместе с их значениями. Посмотрите рисунок 4.

image
Рис. 4

3. Нажмите Add Parameter, чтобы добавить новый параметр для нового компилятора.

4. Введите -useLegacyAOT в поле имени и no в поле значения. Устновите новый параметр для Place before равный -provisioning-profile. Нажмите «OK», чтобы сохранить новый параметр запуска. Посмотрите рисунок 5.
Новый параметр запуска теперь будет выводится на экран в окне запуска Customize launch.

image
Рис. 5

5. Нажмите «OK», чтобы сохранить конфигурацию “Отладка/Выполнение”. Теперь упаковка будет с новым компилятором. 

Flash Pro
Эта функция доступна в Flash Pro CC 2014 и позже. При упаковке для iOS выберите Enable faster packaging, чтобы включить -useLegacyAOT no.

image

Начиная AIR 15.0, упаковочный режим с новый компилятором — является значением по умолчанию. Это означает, что для всех целей AOT таких как ipa-app-store, ipa-test, ipa-ad-hoc и ipa-debug, для упаковки используется новый компилятор. Вы не должны использовать переключатель –useLegacyAOT, чтобы использовать новый упаковочный режим компилятора.

Примечание: Если Вы хотите использовать старый упаковочный режим, используйте переключатель –useLegacyAOT со значением yes в командной строке, или во Flash Builder при упаковке IPA.

Результаты

Новый компилятор значительно уменьшает время упаковки сохраняя ту же производительность.

Время упаковки
Рисунок 6 и 7 иллюстрирует, как новый компилятор почти в 5 — 20 раз быстрее, чем старый компилятор. Для небольших приложений усиление происходит главным образом из-за предварительно скомпилированной встроенной библиотеки.

image
Рис. 6

image
Рис 7.

Производительность во время выполнения
Вы не должны заметить существенные изменения в производительности, во время выполнения приложений упакованных с использованием нового компилятора.

Сообщите в Adobe о любых проблемах с производительностью, если вы таковые испытываете во время выполнения вашего приложения.

Известные проблемы


Новая функциональность компилятора доступна как Бета-версия. Хотя это работает на большинство приложений, Вы можете испытать некоторые проблемы со стабильностью. 

Источник:habrahabr.ru

Комментариев нет:

Отправить комментарий