Gestione degli errori su iOS

Swift fornisce supporto integrato per generare e rilevare errori recuperabili in fase di runtime. Ad esempio, se un'operazione nel codice non va a buon fine o non è valida, l'API genera un errore HomeError. In questo modo, la gestione degli errori viene semplificata e ottimizzata, in quanto puoi concentrarti solo sugli errori recuperabili. Puoi quindi fornire opzioni, ad esempio consentire all'utente di riprovare o visualizzare un messaggio come "Struttura non trovata". Inoltre, poiché non devi gestire esplicitamente ogni possibile eccezione, il codice è meno ingombrante e, di conseguenza, rimane più focalizzato sul suo scopo principale.

Un esempio di come gestire un errore recuperabile:

    let light1 = lightDevices.first
    if let light = light1 {
    do {
      try await structure.move(device: light, to: room)
    } catch let error as HomeError {
      // Code for handling the exception
    }

La tabella seguente fornisce i significati dei codici HomeError che potresti incontrare:

Tabella: HomeError codici
Codice Significato
aborted L'operazione è stata interrotta. Questo messaggio viene visualizzato in genere quando si verifica un problema di concorrenza, ad esempio un errore di controllo della sequenza o un'interruzione della transazione.
alreadyExists La risorsa o l'entità che stai cercando di creare esiste già. Ad esempio, potrebbe trattarsi di una programmazione con nome per un termostato.
cancelled L'operazione è stata annullata, in genere dal chiamante.
dataLoss Perdita o danneggiamento dei dati non recuperabili.
deadlineExceeded La scadenza è trascorsa prima che l'operazione potesse essere completata. Per le operazioni che modificano lo stato del sistema, questo errore potrebbe essere restituito anche se l'operazione è stata completata correttamente. Ad esempio, una risposta riuscita da un server potrebbe essere stata ritardata abbastanza a lungo da far scadere il termine.
failedPrecondition L'operazione è stata rifiutata perché il sistema non si trova nello stato richiesto per l'esecuzione dell'operazione. Ad esempio, potresti ricevere questo messaggio se hai chiamato stop su un forno già spento.
internal Errori interni. Ciò significa che alcuni invarianti previsti dal sistema sottostante sono stati violati. Questo codice di errore è riservato a errori gravi.
invalidArgument Il client ha specificato un argomento non valido. Tieni presente che questo valore è diverso da `failedPrecondition`. `invalidArgument` indica argomenti problematici indipendentemente dallo stato del sistema (ad esempio, un nome file non valido).
notFound Hai specificato un'entità o una risorsa che non è possibile trovare. Ad esempio, specificando un ID traccia inesistente quando si chiama play su un dispositivo lettore multimediale.
outOfRange Un parametro ha superato l'intervallo valido, in base allo stato attuale del sistema. Questo messaggio viene visualizzato quando il valore rientra nell'intervallo di valori che la chiamata API potrebbe potenzialmente accettare, ma non ha senso nel contesto attuale.
permissionDenied Non disponi dell'autorizzazione per eseguire l'operazione specificata. Questo codice di errore non deve essere interpretato nel senso che la richiesta è altrimenti valida.
resourceExhausted Alcune risorse sono esaurite. Ad esempio, questo errore può essere generato quando si chiama dispense(item:amount:unit:presetName:) su un dispositivo di alimentazione per animali domestici e non è rimasto altro cibo nell'unità.
unauthenticated La persona che chiama non può essere identificata o la richiesta non dispone di credenziali di autenticazione valide.
unavailable Il servizio non è disponibile. Si tratta molto probabilmente di una condizione temporanea, che può essere corretta riprovando con un backoff. Tieni presente che non è sempre sicuro riprovare le operazioni non idempotenti.
unimplemented L'operazione richiesta non è implementata, supportata o abilitata in questo servizio.
unknown Errore sconosciuto. In generale, unknown viene visualizzato quando si verifica una condizione di errore che non può essere classificata utilizzando nessuno degli altri codici di errore. Ad esempio, questo errore può essere restituito quando un valore di stato ricevuto da un'API esterna non dispone di informazioni sufficienti sulla causa principale.