zipalign は zip アーカイブ アライメント ツールです。アーカイブ内のすべての非圧縮ファイルを、ファイルの先頭を基準として揃えるようにします。これらのファイルに mmap(2)
から直接アクセスできるようになるため、このデータを RAM にコピーする必要がなくなり、アプリのメモリ使用量を減らせます。
APK ファイルをエンドユーザーに配布する前に zipalign を使用して最適化します。Android Studio(Android Gradle プラグイン(AGP)を使用している)を使ってビルドした場合は、自動的に最適化されます。この場合、引き続き zipalign を使用して APK のアライメントが調整されていることを確認できますが、アライメントを調整する必要はありません。このドキュメントは、カスタム ビルドシステムの管理者を主に対象としています。
注意: ビルドプロセスの特定の時点で zipalign を使用する必要があります。この点は、使用するアプリ署名ツールによって異なります。
アライメントは、zipalign が zip ローカル ファイル ヘッダー セクションの "extra" フィールドのサイズを変更することで行われます。このプロセスでは、"extra" フィールドの既存のデータを変更することもできます。
使用方法
APK に共有ライブラリ(.so ファイル)が含まれている場合は、-P 16 を使用します。
mmap(2) に適した 16 KiB ページ境界に沿って配置されるようにします。
16 KiB と 4 KiB の両方のデバイスで保存されています。それ以外のファイルについては、
zipalign に対する必須のアライメント引数。4 バイトにアライメントする必要があります。
32 ビットと 64 ビットの両方のシステムに対応しています。
infile.apk のアライメントを調整して outfile.apk として保存するには:
zipalign -P 16 -f -v 4 infile.apk outfile.apk
existing.apk の配置を確認するには、次のコマンドを使用します。
zipalign -c -P 16 -v 4 existing.apk
オプション
次の表に、使用可能な zipalign オプションを示します。
| オプション | 説明 |
|---|---|
| -c | 配置のみを確認します(ファイルは変更しません)。 |
| -f | 既存の出力ファイルを上書きします。 |
| -h | ツールのヘルプを表示します。 |
| -P <ページサイズ_kb> | 非圧縮 .so ファイルを、指定された KiB 単位でページサイズに揃えます。有効なオプション
<pagesize_kb> は 4、16、64 です。 |
| -p | 4 KiB は、非圧縮の .so ファイルをページ調整します。Google Cloud コンソールから
-p が非推奨になったため、代わりに -P 16 を使用します。 |
| -v | 詳細な出力を行います。 |
| -z | Zopfli を使用して再圧縮します。 |