C ++ swscanf () - Libreria standard C ++

La funzione swscanf () in C ++ legge i caratteri wide dal buffer delle stringhe larghe.

La funzione swscanf () è definita nel file di intestazione.

prototipo swscanf ()

 int swscanf (const wchar_t * buffer, const wchar_t * formato,…);

La funzione swscanf () legge i dati dal buffer e memorizza i valori nelle rispettive variabili.

Parametri swscanf ()

  • buffer: puntatore al buffer della stringa ampia da cui leggere i dati.
  • format: puntatore a una stringa di caratteri con terminazione null che specifica come leggere l'input. Consiste di identificatori di formato che iniziano con%.
    La stringa di formato ha le seguenti parti:
    • Caratteri diversi da spazi tranne% ognuno dei quali consuma un carattere identico dal flusso di input. Può causare il fallimento della funzione se il carattere successivo nello stream non è uguale.
    • Carattere di spazio bianco: tutti i caratteri di spazio bianco consecutivi vengono trattati come un singolo carattere di spazio vuoto. Inoltre, " n", " t" e "" sono considerati uguali.
    • Specifica di conversione: segue il seguente formato:
      • Carattere% iniziale che specifica l'inizio
      • Un carattere facoltativo * chiamato soppressione delle assegnazioni. Se questo carattere è presente, swscanf () non assegna il risultato a nessun argomento ricevente.
      • Un numero intero positivo facoltativo che specifica la larghezza massima del campo. Specifica il numero massimo di caratteri che swscanf () può utilizzare durante la conversione specificata dalla specifica di conversione corrente.
      • Un modificatore di lunghezza opzionale che specifica la dimensione dell'argomento ricevente.
      • Un identificatore di formato di conversione.
    Identificatori di formato
    Identificatore di formato Descrizione
    % Corrisponde alla% letterale
    c Corrisponde a uno o più caratteri. Se la larghezza è definita, corrisponde esattamente ai caratteri di larghezza.
    S Corrisponde a caratteri consecutivi non spazi bianchi. Se la larghezza è definita, corrisponde esattamente ai caratteri di larghezza o fino a quando non viene trovato il primo spazio bianco.
    (impostato) Corrisponde a una sequenza di caratteri non vuota dal set di caratteri specificato. Se è presente all'inizio del set, tutti i caratteri non presenti nel set vengono abbinati.
    d Corrisponde a un numero intero decimale.
    io Corrisponde a un numero intero.
    o Corrisponde a un numero intero ottale senza segno.
    X o x Corrisponde a un numero intero esadecimale senza segno.
    u Corrisponde a un numero intero decimale senza segno.
    A o a, E o e, F o f, G o g Corrisponde a un numero in virgola mobile.
    n Restituisce il numero di caratteri letti fino a quel momento.
    p Corrisponde a una sequenza di caratteri definita dall'implementazione che definisce un puntatore.

    Quindi il formato generale dell'identificatore di formato è:
     Identificatore% (*) (larghezza) (lunghezza)
  • …: altri argomenti aggiuntivi per la ricezione dei dati. Si verificano in una sequenza in base all'identificatore di formato.

swscanf () Restituisce il valore

  • La funzione swscanf () restituisce il numero di argomenti di ricezione assegnati con successo.
  • Se si verifica un errore prima dell'assegnazione del primo argomento ricevente, viene restituito EOF .

Esempio: come funziona la funzione swscanf ()?

 #include #include int main() ( wchar_t buffer(100) = L"Theta u03b8"; wchar_t symbol, desc(10); setlocale(LC_ALL, "en_US.UTF-8"); swscanf(buffer, L"%ls %lc", desc, &symbol); wprintf(L"%lc is %ls", symbol, desc); return 0; )

Quando esegui il programma, un possibile output sarà:

 θ è Theta

Articoli interessanti...