プロダクト ニュース

Android 17 のベータ版 4

所要時間: 4 分
Daniel Galpin
デベロッパー アドボケイト

Android 17 はベータ版 4 に到達しました。これはこのリリース サイクルの最後の予定ベータ版であり、アプリの互換性とプラットフォームの安定性にとって重要なマイルストーンです。アプリのユーザー エクスペリエンスの微調整、エッジ ツー エッジのレンダリングの円滑化、最新の API の活用など、ベータ版 4 では、テストに必要なほぼ最終版の環境が提供されます。

アプリ、ライブラリ、ツール、ゲームエンジンを準備しましょう

Android SDK、ライブラリ、ツール、ゲームエンジンを開発している場合は、互換性の問題によって下流のアプリやゲームのデベロッパーがブロックされるのを防ぎ、最新の SDK 機能を利用できるようにするために、必要なアップデートを今すぐ準備することが重要です。Android 17 を完全にサポートするためにアップデートが必要な場合は、ダウンストリーム デベロッパーにお知らせください。

Android17_Timeline_01_V02.png

テストでは、Android 17 ベータ版 4 を実行しているデバイスまたはエミュレータに、Google Play またはその他の手段を使用して、ライブラリまたはエンジンを利用する本番環境アプリまたはテストアプリをインストールします。アプリのすべてのフローをテストし、機能や UI の問題を探します。Android の各リリースには、プライバシー、セキュリティ、全体的なユーザー エクスペリエンスを向上させるプラットフォームの変更が含まれています。Android 17 で実行されるアプリと Android 17 をターゲットとするアプリの動作変更のうち、アプリに影響するものについて確認し、テストの対象を絞り込みます。たとえば、以下のような変更があります。

  • 大画面でのサイズ変更: Android 17 をターゲットにすると、大画面での画面の向き、サイズ変更、アスペクト比の制約の維持を無効にすることはできなくなります。
  • 動的コードの読み込み: アプリが Android 17 以降をターゲットとしている場合、DEX ファイルと JAR ファイルを対象とする Android 14 で導入された動的コードのより安全な読み込み(DCL)保護が、ネイティブ ライブラリにも拡張されます。System.load() を使用して読み込まれるすべてのネイティブ ファイルは、読み取り専用としてマークされている必要があります。そうしないと、システムは UnsatisfiedLinkError をスローします。
  • デフォルトで CT を有効化: Certificate Transparency(CT)がデフォルトで有効になります。(Android 16 では CT を利用できますが、アプリは オプトインする必要がありました)。
  • ローカル ネットワークの保護: Android 17 以上をターゲットとするアプリでは、ローカル ネットワーク アクセスがデフォルトでブロックされます。可能であれば、プライバシーを保護するピッカーの使用に切り替え、広範で永続的なアクセスには新しい ACCESS_LOCAL_NETWORK 権限を使用します。
  • バックグラウンド オーディオの強化: Android 17 以降では、オーディオ フレームワークが、オーディオ再生、音声フォーカス リクエスト、音量変更 API など、バックグラウンド オーディオのインタラクションに関する制限を適用します。ベータ版 2 以降、皆様からのフィードバックに基づき、使用中の FGS の適用時に targetSDK のゲートを設けたり、アラームの音声を免除したりするなど、いくつかの変更を行いました。詳しくは、更新されたガイダンスをご覧ください。

アプリのメモリ上限

Android では、デバイスの合計 RAM に基づくアプリのメモリ制限を導入し、アプリと Android ユーザーにとってより安定した決定論的な環境を構築します。Android 17 では、システム ベースラインを確立するために上限が控えめに設定されており、極端なメモリリークやその他の外れ値が、システム全体の不安定さを引き起こし、UI のスタッタリング、バッテリーの消耗、アプリの強制終了につながる前に、それらをターゲットにしています。ほとんどのアプリ セッションへの影響は最小限に抑えられると予想されますが、メモリのベースラインを確立するなど、メモリに関する次のベスト プラクティスをおすすめします。

現在の実装では、アプリが影響を受けた場合、ApplicationExitInfogetDescription に「MemoryLimiter」という文字列が含まれます。また、TRIGGER_TYPE_ANOMALYトリガーベースのプロファイリングを使用すると、メモリ上限に達したときに収集されるヒープダンプを取得できます。

unnamed (2).png
Android Studio Profiler の LeakCanary タスク

メモリリークの検出を支援するため、Android Studio Panda では、Android Studio プロファイラに LeakCanary 統合が専用タスクとして直接追加されています。このタスクは IDE 内でコンテキスト化され、ソースコードと完全に統合されています。

メモリ使用量が少ないほど、パフォーマンスが向上し、バッテリー駆動時間が長くなり、あらゆるフォーム ファクタで優れたエクスペリエンスを実現できます。Android エコシステムのより高速で信頼性の高い未来を一緒に築きましょう。

アプリの異常のプロファイリング トリガー

Android には、リソースを大量に消費する動作や互換性の潜在的な回帰をモニタリングするオンデバイスの異常検出サービスが導入されています。ProfilingManager と統合されたこのサービスにより、アプリはシステムが検出した特定のイベントによってトリガーされたプロファイリング アーティファクトを受け取ることができます。

TRIGGER_TYPE_ANOMALY トリガーを使用して、バインダ呼び出しの過多やメモリ使用量の過多などのシステム パフォーマンスの問題を検出します。アプリが OS で定義されたメモリ上限を超えると、異常トリガーにより、デベロッパーはアプリ固有のヒープダンプを受け取って、メモリの問題を特定して修正できます。また、バインダー スパムが過剰な場合、異常トリガーはバインダー トランザクションのスタック サンプリング プロファイルを提供します。

この API コールバックは、システムが強制適用する前に発生します。たとえば、メモリ上限を超えてシステムによってアプリが終了する前に、デバッグデータを収集するのに役立ちます。トリガーの使用方法については、トリガーベースのプロファイリングに関するドキュメントをご覧ください。

    val profilingManager = applicationContext.getSystemService(ProfilingManager::class.java)
    val triggers = ArrayList<ProfilingTrigger>()  
    triggers.add(ProfilingTrigger.Builder(
                 ProfilingTrigger.TRIGGER_TYPE_ANOMALY))
    val mainExecutor: Executor = Executors.newSingleThreadExecutor()
    val resultCallback = Consumer<ProfilingResult> { profilingResult ->
        if (profilingResult.errorCode != ProfilingResult.ERROR_NONE) {
            // upload profile result to server for further analysis          
            setupProfileUploadWorker(profilingResult.resultFilePath)
        } 
    profilingManager.registerForAllProfilingResults(mainExecutor, resultCallback)
    profilingManager.addProfilingTriggers(triggers)
}

Android Keystore のポスト量子暗号(PQC)

Android キーストアで、NIST 標準化 ML-DSA(Module-Lattice-Based Digital Signature Algorithm)のサポートが追加されました。対応デバイスでは、ML-DSA 鍵を生成し、デバイスの安全なハードウェア内で耐量子署名を生成できます。Android Keystore は、標準の Java Cryptographic Architecture API(KeyPairGeneratorKeyFactorySignature)を通じて ML-DSA-65 と ML-DSA-87 のアルゴリズム バリアントを公開します。詳しくは、デベロッパー向けドキュメントをご覧ください。

KeyPairGenerator generator = KeyPairGenerator.getInstance(
        ML-DSA-65, "AndroidKeyStore");
generator.initialize(
        new KeyGenParameterSpec.Builder(
                my-key-alias,
                KeyProperties.PURPOSE_SIGN | KeyProperties.PURPOSE_VERIFY)
        .build());
KeyPair keyPair = generator.generateKeyPair();

Android 17 を使ってみる

サポートされている Pixel デバイスを登録すると、このアップデートと今後の Android ベータ版のアップデートを無線(OTA)で入手できます。Google Pixel デバイスをお持ちでない場合は、Android Studio で Android Emulator で 64 ビット システム イメージを使用することができます。

現在 Android ベータ プログラムに参加している場合は、ベータ版 4 への無線(OTA)アップデートが提供されます。

フィードバック ページで、引き続き問題を報告し、機能リクエストを送信してください。早期にフィードバックをお送りいただくと、最終リリースにより多くのフィードバックを反映させることができます。

Android 17 で最適な開発エクスペリエンスを実現するには、Android Studio(Panda)の最新プレビュー版を使用することをおすすめします。セットアップが完了したら、次の手順を行います。

  • 新しい SDK でコンパイルし、CI 環境でテストし、フィードバック ページのトラッカーで問題を報告してください。
  • 現在のアプリの互換性をテストし、Android 17 の変更による影響を受けるかどうかを確認します。また、Android 17 を実行しているデバイスまたはエミュレータにアプリをインストールして、徹底的にテストします。

Android 17 のリリース サイクルを通して、プレビュー/ベータ版のシステム イメージと SDK は定期的に更新されます。ベータ版ビルドをインストールすると、それ以降のすべてのプレビュー版とベータ版のアップデートが無線(OTA)で自動的に提供されます。

詳細については、Android 17 デベロッパー サイトをご覧ください。

会話に参加する

皆様からのフィードバックは、Google にとって最も貴重な財産です。Canary チャンネルのアーリー アダプターの方も、Beta 4 でテストしているアプリ デベロッパーの方も、ぜひコミュニティに参加してフィードバックをお寄せください。ぜひお聞かせください。

作成者:

続きを読む