<uses-sdk>

Google Play utilizza gli attributi <uses-sdk> dichiarati nel file manifest dell'app per filtrare l'app dai dispositivi che non soddisfano i requisiti della versione della piattaforma. Prima di impostare questi attributi, assicurati di comprendere i filtri di Google Play.

sintassi:
<uses-sdk android:minSdkVersion="integer"
          android:targetSdkVersion="integer"
          android:maxSdkVersion="integer" />
contenuto in:
<manifest>
description:

Consente di esprimere la compatibilità di un'applicazione con una o più versioni della piattaforma Android tramite un numero intero del livello API. Il livello API espresso da un'applicazione viene confrontato con il livello API di un determinato sistema Android, che può variare a seconda dei dispositivi Android.

Nonostante il nome, questo elemento viene utilizzato per specificare il livello API, non il numero di versione del software development kit (SDK) o della piattaforma Android. Il livello API è sempre un singolo numero intero. Non puoi derivare il livello API dal numero di versione di Android associato. Ad esempio, non corrisponde alla versione principale o alla somma delle versioni principali e secondarie.

Non è possibile specificare che un'app abbia come target o richieda una versione secondaria dell'SDK.

Leggi anche il documento sul controllo delle versioni delle applicazioni.

attributi:
android:minSdkVersion
Un numero intero che indica il livello API minimo richiesto per l'esecuzione dell'applicazione. Il sistema Android impedisce all'utente di installare l'applicazione se il livello API del sistema è inferiore al valore specificato in questo attributo. Dichiara sempre questo attributo.

Attenzione:se non dichiari questo attributo, il sistema presuppone un valore predefinito di "1", che indica che la tua applicazione è compatibile con tutte le versioni di Android. Se non lo è e non hai dichiarato il valore minSdkVersion corretto, quando viene installata su un sistema con un livello API incompatibile, l'applicazione si arresta in modo anomalo durante l'esecuzione quando tenta di accedere alle API non disponibili. Per questo motivo, assicurati di dichiarare il livello API appropriato nell'attributo minSdkVersion.

android:targetSdkVersion
Un numero intero che indica il livello API a cui fa riferimento l'applicazione. Se non viene impostato, il valore predefinito è uguale a quello assegnato a minSdkVersion.

Questo attributo comunica al sistema che hai eseguito test sulla versione di destinazione e che il sistema non attiva alcun comportamento di compatibilità per mantenere la compatibilità futura dell'app con la versione di destinazione. L'applicazione è ancora in grado di essere eseguita su versioni precedenti (fino a minSdkVersion).

Per via dell'evoluzione di Android a ogni nuova versione, alcuni comportamenti e persino aspetti visivi possono cambiare. Tuttavia, se il livello API della piattaforma è superiore alla versione dichiarata dal targetSdkVersion della tua app, il sistema può attivare comportamenti di compatibilità in modo che la tua app continui a funzionare come previsto. Puoi disattivare questi comportamenti di compatibilità specificando targetSdkVersion in modo che corrisponda al livello API della piattaforma su cui viene eseguito.

Ad esempio, se imposti questo valore su "11" o un valore superiore, il sistema applica il tema Holo predefinito alla tua app quando viene eseguita su Android 3.0 o versioni successive e disattiva anche la modalità di compatibilità dello schermo quando viene eseguita su schermi più grandi, perché il supporto del livello API 11 supporta implicitamente schermi più grandi.

Esistono molti comportamenti di compatibilità che il sistema può attivare in base al valore impostato per questo attributo. Molti di questi comportamenti sono descritti dalle versioni della piattaforma corrispondenti nel riferimento Build.VERSION_CODES.

Per mantenere la tua applicazione insieme a ogni release di Android, aumenta il valore di questo attributo in modo che corrisponda al livello API più recente, quindi testa a fondo la tua applicazione sulla versione della piattaforma corrispondente.

Introdotto in: livello API 4

android:maxSdkVersion
Un numero intero che indica il livello API massimo su cui è progettata l'applicazione.

In Android 1.5, 1.6, 2.0 e 2.0.1, il sistema controlla il valore di questo attributo durante l'installazione di un'applicazione e durante la convalida dell'applicazione dopo un aggiornamento di sistema. In entrambi i casi, se l'attributo maxSdkVersion dell'applicazione è inferiore al livello API utilizzato dal sistema stesso, il sistema non consente l'installazione dell'applicazione. In caso di nuova convalida dopo l'aggiornamento del sistema, l'applicazione viene rimossa dal dispositivo.

Per illustrare in che modo questo attributo può influire sulla tua applicazione dopo gli aggiornamenti del sistema, considera il seguente esempio:

Un'applicazione che dichiara maxSdkVersion="5" nel manifest viene pubblicata su Google Play. Un utente il cui dispositivo esegue Android 1.6 (livello API 4) scarica e installa l'app. Dopo alcune settimane, l'utente riceve un aggiornamento di sistema over-the-air ad Android 2.0 (livello API 5). Dopo l'installazione dell'aggiornamento, il sistema controlla il maxSdkVersion dell'applicazione e lo convalida nuovamente.

L'applicazione funziona normalmente. Tuttavia, qualche tempo dopo, il dispositivo riceve un altro aggiornamento di sistema, questa volta ad Android 2.0.1 (livello API 6). Dopo l'aggiornamento, il sistema non può più convalidare nuovamente l'applicazione perché il livello API proprio del sistema (6) è ora superiore a quello massimo supportato dall'applicazione (5). Il sistema impedisce all'applicazione di essere visibile all'utente, di fatto rimuovendola dal dispositivo.

Avviso:sconsigliamo di dichiarare questo attributo. Innanzitutto, non è necessario impostare l'attributo come mezzo per bloccare il deployment dell'applicazione sulle nuove versioni della piattaforma Android man mano che vengono rilasciate. Per progettazione, le nuove versioni della piattaforma sono completamente compatibili con le versioni precedenti. La tua applicazione funziona correttamente sulle nuove versioni, a condizione che utilizzi solo API standard e segua le best practice di sviluppo. In secondo luogo, in alcuni casi la dichiarazione dell'attributo può comportare la rimozione dell'applicazione dai dispositivi degli utenti dopo un aggiornamento di sistema a un livello API superiore. La maggior parte dei dispositivi su cui è probabile che venga installata la tua applicazione riceve aggiornamenti di sistema periodici via OTA, quindi valuta il loro effetto sulla tua applicazione prima di impostare questo attributo.

Introdotto in: livello API 4

Alcune versioni di Android (oltre Android 2.0.1) non controllano né applicano l'attributo maxSdkVersion durante l'installazione o la convalida. Google Play continua a utilizzare l'attributo come filtro, tuttavia, quando presenta agli utenti le applicazioni disponibili per il download.
introdotto in:
Livello API 1

Che cos'è il livello API?

Il livello API è un valore intero che identifica in modo univoco la revisione dell'API framework offerta da una versione della piattaforma Android.

La piattaforma Android fornisce un'API framework che le applicazioni possono utilizzare per interagire con il sistema Android sottostante. L'API del framework è costituita da:

  • Un insieme di pacchetti e classi di base
  • Un insieme di elementi e attributi XML per dichiarare un file manifest
  • Un insieme di elementi e attributi XML per dichiarare e accedere alle risorse
  • Un insieme di intent
  • Un insieme di autorizzazioni che le applicazioni possono richiedere, nonché l'applicazione delle autorizzazioni incluse nel sistema

Ogni versione successiva della piattaforma Android può includere aggiornamenti all'API del framework delle applicazioni Android che fornisce.

Gli aggiornamenti dell'API framework sono progettati in modo che la nuova API rimanga compatibile con le versioni precedenti dell'API. ovvero la maggior parte delle modifiche all'API sono additive e introducono funzionalità nuove o sostitutive. Man mano che vengono eseguiti gli upgrade delle parti dell'API, le parti sostituite meno recenti vengono ritirate, ma non rimosse, in modo che le applicazioni esistenti possano comunque utilizzarle.

In un numero molto ridotto di casi, parti dell'API vengono modificate o rimosse, anche se in genere queste modifiche sono necessarie solo per supportare la robustezza dell'API e la sicurezza di applicazioni o sistemi. Tutte le altre parti dell'API delle revisioni precedenti vengono riportate senza modifiche.

L'API framework fornita da una piattaforma Android viene specificata utilizzando un identificatore intero chiamato livello API. Ogni versione della piattaforma Android supporta esattamente un livello API, anche se il supporto è implicito per tutti i livelli API precedenti (fino al livello API 1). La release iniziale della piattaforma Android forniva il livello API 1 e le release successive hanno incrementato il livello API.

La tabella seguente specifica il livello API supportato da ogni versione della piattaforma Android. Per informazioni sul numero relativo di dispositivi su cui è in esecuzione ogni versione, consulta la dashboard di distribuzione.

Versione piattaformaLivello APIVERSION_CODENote
Android 16 36 BAKLAVA Punti salienti della piattaforma
Android 15 35 VANILLA_ICE_CREAM Punti salienti della piattaforma
Android 14 34 UPSIDE_DOWN_CAKE Punti salienti della piattaforma
Android 13 33 TIRAMISU Punti salienti della piattaforma
Android 12 32 S_V2 Punti salienti della piattaforma
31 S Punti salienti della piattaforma
Android 11 30 R Punti salienti della piattaforma
Android 10 29 Q Punti salienti della piattaforma
Android 9 28 P Punti salienti della piattaforma
Android 8.1 27 O_MR1 Punti salienti della piattaforma
Android 8.0 26 O Punti salienti della piattaforma
Android 7.1.1
Android 7.1
25 N_MR1 Punti salienti della piattaforma
Android 7.0 24 N Punti salienti della piattaforma
Android 6.0 23 M Punti salienti della piattaforma
Android 5.1 22 LOLLIPOP_MR1 Punti salienti della piattaforma
Android 5.0 21 LOLLIPOP
Android 4.4W 20 KITKAT_WATCH KitKat solo per indossabili
Android 4.4 19 KITKAT Punti salienti della piattaforma
Android 4.3 18 JELLY_BEAN_MR2 Punti salienti della piattaforma
Android 4.2, 4.2.2 17 JELLY_BEAN_MR1 Punti salienti della piattaforma
Android 4.1, 4.1.1 16 JELLY_BEAN Punti salienti della piattaforma
Android 4.0.3, 4.0.4 15 ICE_CREAM_SANDWICH_MR1 Punti salienti della piattaforma
Android 4.0, 4.0.1, 4.0.2 14 ICE_CREAM_SANDWICH
Android 3.2 13 HONEYCOMB_MR2
Android 3.1.x 12 HONEYCOMB_MR1 Punti salienti della piattaforma
Android 3.0.x 11 HONEYCOMB Punti salienti della piattaforma
Android 2.3.4
Android 2.3.3
10 GINGERBREAD_MR1 Punti salienti della piattaforma
Android 2.3.2
Android 2.3.1
Android 2.3
9 GINGERBREAD
Android 2.2.x 8 FROYO Punti salienti della piattaforma
Android 2.1.x 7 ECLAIR_MR1 Punti salienti della piattaforma
Android 2.0.1 6 ECLAIR_0_1
Android 2.0 5 ECLAIR
Android 1.6 4 DONUT Punti salienti della piattaforma
Android 1.5 3 CUPCAKE Punti salienti della piattaforma
Android 1.1 2 BASE_1_1
Android 1.0 1 BASE

Utilizzi del livello API in Android

L'identificatore del livello API svolge un ruolo fondamentale nel garantire la migliore esperienza possibile per utenti e sviluppatori di applicazioni:

  • Consente alla piattaforma Android di descrivere la revisione massima dell'API framework che supporta.
  • Consente alle applicazioni di descrivere la revisione dell'API del framework richiesta.
  • Consente al sistema di negoziare l'installazione delle applicazioni sul dispositivo dell'utente in modo che non vengano installate applicazioni incompatibili con la versione.

Ogni versione della piattaforma Android memorizza internamente il proprio identificatore del livello API, nel sistema Android stesso.

Le applicazioni possono utilizzare un elemento manifest fornito dall'API framework, <uses-sdk>, per descrivere i livelli API minimi e massimi in cui possono essere eseguite, nonché il livello API preferito che sono progettate per supportare. L'elemento offre tre attributi chiave:

  • android:minSdkVersion: il livello API minimo su cui l'applicazione è in grado di essere eseguita. Il valore predefinito è "1".
  • android:targetSdkVersion: il livello API su cui è progettata l'applicazione. In alcuni casi, ciò consente all'applicazione di utilizzare elementi manifest o comportamenti definiti nel livello API di destinazione, anziché essere limitata all'utilizzo solo di quelli definiti per il livello API minimo.
  • android:maxSdkVersion: il livello API massimo su cui l'applicazione è in grado di essere eseguita. Importante:prima di utilizzare questo attributo, leggi le informazioni riportate in questa pagina.

Ad esempio, per specificare il livello API di sistema minimo richiesto da un'applicazione per essere eseguita, l'applicazione include nel manifest un elemento <uses-sdk> con un attributo android:minSdkVersion. Il valore di android:minSdkVersion è l'intero corrispondente al livello API della prima versione della piattaforma Android in cui l'applicazione può essere eseguita.

Quando l'utente tenta di installare un'applicazione o quando convalida nuovamente un'applicazione dopo un aggiornamento del sistema, il sistema Android controlla innanzitutto gli attributi <uses-sdk> nel manifest dell'applicazione e confronta i valori con il proprio livello API interno. Il sistema consente l'inizio dell'installazione solo se vengono soddisfatte le seguenti condizioni:

  • Se viene dichiarato un attributo android:minSdkVersion, il suo valore è minore o uguale all'intero del livello API del sistema. Se non viene dichiarato, il sistema presuppone che l'applicazione richieda il livello API 1.
  • Se viene dichiarato un attributo android:maxSdkVersion, il suo valore è maggiore o uguale all'intero del livello API del sistema. Se non viene dichiarato, il sistema presuppone che l'applicazione non abbia un livello API massimo. Leggi la descrizione di questo attributo per saperne di più su come viene gestito dal sistema.

Se dichiarato nel manifest di un'applicazione, un elemento <uses-sdk> potrebbe avere il seguente aspetto:

<manifest>
  <uses-sdk android:minSdkVersion="5" />
  ...
</manifest>

Il motivo principale per cui un'applicazione dichiara un livello API in android:minSdkVersion è comunicare al sistema Android che utilizza API introdotte nel livello API specificato.

Se l'applicazione viene installata in qualche modo su una piattaforma con un livello API inferiore, si arresta in modo anomalo in fase di runtime quando tenta di accedere ad API inesistenti. Il sistema impedisce questo risultato non consentendo l'installazione dell'applicazione se il livello API minimo richiesto è superiore a quello della versione della piattaforma sul dispositivo di destinazione.

Considerazioni sullo sviluppo

Le sezioni seguenti forniscono informazioni relative al livello API da considerare durante lo sviluppo dell'applicazione.

Compatibilità futura delle applicazioni

Le applicazioni per Android sono generalmente compatibili con le nuove versioni della piattaforma Android.

Poiché quasi tutte le modifiche all'API framework sono additive, un'applicazione Android sviluppata utilizzando una determinata versione dell'API, come specificato dal relativo livello API, è compatibile con le versioni successive della piattaforma Android e con i livelli API più elevati. L'applicazione può essere eseguita su tutte le versioni successive della piattaforma Android, tranne in casi isolati in cui l'applicazione utilizza una parte dell'API che viene rimossa in un secondo momento per qualche motivo.

La compatibilità futura è importante perché molti dispositivi Android ricevono aggiornamenti di sistema over-the-air (OTA). L'utente potrebbe installare la tua applicazione e utilizzarla correttamente, per poi ricevere un aggiornamento OTA a una nuova versione della piattaforma Android. Una volta installato l'aggiornamento, l'applicazione viene eseguita in una nuova versione di runtime dell'ambiente, ma che dispone ancora delle funzionalità API e di sistema da cui dipende l'applicazione.

Le modifiche sotto l'API, come quelle nel sistema sottostante, possono influire sulla tua applicazione quando viene eseguita nel nuovo ambiente. In qualità di sviluppatore dell'applicazione, è importante che tu comprenda l'aspetto e il comportamento dell'applicazione in ogni ambiente di sistema.

Per aiutarti a testare la tua applicazione su varie versioni della piattaforma Android, l'SDK Android include più piattaforme che puoi scaricare. Ogni piattaforma include un'immagine di sistema compatibile che puoi eseguire in un AVD per testare la tua applicazione.

Compatibilità con le versioni precedenti delle applicazioni

Le applicazioni Android non sono necessariamente compatibili con le versioni della piattaforma Android precedenti a quella con cui sono state compilate.

Ogni nuova versione della piattaforma Android può includere nuove API framework, ad esempio quelle che consentono alle applicazioni di accedere a nuove funzionalità della piattaforma o sostituire parti di API esistenti. Le nuove API sono accessibili alle applicazioni quando vengono eseguite sulla nuova piattaforma e anche quando vengono eseguite su versioni successive della piattaforma, come specificato dal livello API. Tuttavia, poiché le versioni precedenti della piattaforma non includono le nuove API, le applicazioni che le utilizzano non possono essere eseguite su queste piattaforme.

Anche se è improbabile che un dispositivo basato su Android venga eseguito il downgrade a una versione precedente della piattaforma, è importante rendersi conto che è probabile che sul campo siano presenti molti dispositivi che eseguono versioni precedenti della piattaforma. Anche tra i dispositivi che ricevono aggiornamenti OTA, alcuni potrebbero essere in ritardo e potrebbero non ricevere un aggiornamento per un periodo di tempo significativo.

Seleziona una versione della piattaforma e un livello API

Quando sviluppi l'applicazione, scegli la versione della piattaforma rispetto alla quale compili l'applicazione. In generale, compila l'applicazione in base alla versione più bassa possibile della piattaforma che può supportare.

Puoi determinare la versione della piattaforma più bassa possibile compilando l'applicazione in base a target di build progressivamente inferiori. Dopo aver determinato la versione più bassa, crea un AVD utilizzando la versione della piattaforma e il livello API corrispondenti e testa completamente l'applicazione. Assicurati di dichiarare un attributo android:minSdkVersion nel manifest dell'applicazione e imposta il relativo valore sul livello API della versione della piattaforma.

Dichiarare un livello API minimo

Se crei un'applicazione che utilizza API o funzionalità di sistema introdotte nell'ultima versione della piattaforma, imposta l'attributo android:minSdkVersion sul livello API dell'ultima versione della piattaforma. In questo modo, gli utenti possono installare la tua applicazione solo se sui loro dispositivi è in esecuzione una versione compatibile della piattaforma Android. A sua volta, ciò contribuisce a garantire che la tua applicazione possa funzionare correttamente sui loro dispositivi.

Se la tua applicazione utilizza API introdotte nell'ultima versione della piattaforma, ma non dichiara un attributo android:minSdkVersion, allora viene eseguita correttamente sui dispositivi con l'ultima versione della piattaforma, ma non sui dispositivi con versioni precedenti della piattaforma. In quest'ultimo caso, l'applicazione si arresta in modo anomalo in fase di runtime quando tenta di utilizzare API che non esistono nelle versioni precedenti.

Testare con livelli API più elevati

Dopo aver compilato l'applicazione, assicurati di testarla sulla piattaforma specificata nell'attributo android:minSdkVersion dell'applicazione. Per farlo, crea un AVD che utilizzi la versione della piattaforma richiesta dalla tua applicazione. Inoltre, per verificare la compatibilità futura, esegui e testa l'applicazione su tutte le piattaforme che utilizzano un livello API superiore a quello utilizzato dalla tua applicazione.

L'SDK Android include più versioni della piattaforma che puoi utilizzare, inclusa l'ultima versione, e fornisce uno strumento di aggiornamento che puoi utilizzare per scaricare altre versioni della piattaforma, se necessario.

Per accedere all'utilità di aggiornamento, utilizza lo strumento a riga di comando android, che si trova nella directory <sdk>/tools. Puoi avviare lo strumento di aggiornamento dell'SDK eseguendo android sdk. Puoi anche fare doppio clic sul file android.bat (Windows) o android (OS X/Linux).

Per eseguire l'applicazione su diverse versioni della piattaforma nell'emulatore, crea un AVD per ogni versione della piattaforma che vuoi testare. Per saperne di più sugli AVD, consulta Creare e gestire dispositivi virtuali. Se utilizzi un dispositivo fisico per i test, assicurati di conoscere il livello API della piattaforma Android su cui viene eseguito. Consulta la tabella in questo documento per un elenco delle versioni della piattaforma e dei relativi livelli API.

Filtrare la documentazione di riferimento in base al livello API

Le pagine della documentazione di riferimento della piattaforma Android offrono un controllo "Livello API" nell'area in alto a sinistra di ogni pagina. Puoi utilizzare il controllo per mostrare la documentazione solo per le parti dell'API effettivamente accessibili alla tua applicazione, in base al livello API specificato nell'attributo android:minSdkVersion del file manifest.

Per utilizzare il filtro, seleziona dal menu il livello API specificato dalla tua applicazione. Le API introdotte in un livello API successivo vengono visualizzate in grigio e i relativi contenuti vengono mascherati, in quanto non sono accessibili alla tua applicazione.

Il filtro per livello API nella documentazione non fornisce una visualizzazione di ciò che è nuovo o introdotto in ogni livello API. Fornisce un modo per visualizzare l'intera API associata a un determinato livello API, escludendo gli elementi API introdotti nei livelli API successivi.

Per tornare alla visualizzazione della documentazione completa, seleziona REL nella parte superiore del menu del livello API. Per impostazione predefinita, il filtro a livello di API è disattivato, in modo da poter visualizzare l'API framework completa, indipendentemente dal livello API.

La documentazione di riferimento per i singoli elementi dell'API specifica il livello API in cui viene introdotto ogni elemento. Il livello API per pacchetti e classi è specificato come "Aggiunto nel livello API" nell'angolo in alto a destra dell'area dei contenuti di ogni pagina della documentazione. Il livello API per i membri della classe è specificato nelle intestazioni della descrizione dettagliata, nel margine destro.