C ++ wscanf () - Libreria standard C ++

La funzione wscanf () in C ++ legge i caratteri wide dallo stdin.

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

Prototipo wscanf ()

 int wscanf (const char * formato,…);

La funzione wscanf () legge i dati dallo stdin e memorizza i valori nelle rispettive variabili.

Parametri wscanf ()

  • 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, wscanf () 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 wscanf () 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.

wscanf () Restituisce il valore

  • La funzione wscanf () 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 wscanf ()?

 #include #include #include #include using namespace std; int main() ( wchar_t hebrew_str() = L"u05D0 u05D1 u05E1 u05D3 u05EA"; wchar_t ch; setlocale(LC_ALL, "en_US.UTF-8"); wprintf(L"Enter a wide character: "); wscanf(L"%lc",&ch); if (iswalnum(ch)) wcout << ch << L" is alphanumeric." << endl; else wcout << ch << L" is not alphanumeric." << endl; return 0; )

Quando esegui il programma, un possibile output sarà:

 Immettere un carattere ampio: ∭ ∭ non è alfanumerico.

Articoli interessanti...