A função swscanf () em C ++ lê caracteres largos do buffer de string ampla.
A função swscanf () é definida no arquivo de cabeçalho.
protótipo swscanf ()
int swscanf (const wchar_t * buffer, const wchar_t * format,…);
A função swscanf () lê os dados do buffer e armazena os valores nas respectivas variáveis.
Parâmetros swscanf ()
- buffer: Ponteiro para o buffer de string de onde ler os dados.
- formato: ponteiro para uma string de caracteres terminada em nulo que especifica como ler a entrada. Consiste em especificadores de formato começando com%.
A string de formato tem as seguintes partes:- Caracteres sem espaço em branco, exceto%, cada um dos quais consome um caractere idêntico do fluxo de entrada. Isso pode fazer com que a função falhe se o próximo caractere no fluxo não for igual.
- Caractere de espaço em branco: todos os caracteres de espaço em branco consecutivos são tratados como um único caractere de espaço em branco. Além disso, ' n', ' t' e '' são considerados iguais.
- Especificação de conversão: segue o seguinte formato:
- Caractere% inicial que especifica o início
- Um * opcional denominado caractere de supressão de atribuição. Se este caractere estiver presente, swscanf () não atribui o resultado a nenhum argumento receptor.
- Um número inteiro positivo opcional que especifica a largura máxima do campo. Ele especifica o número máximo de caracteres que swscanf () pode consumir ao fazer a conversão especificada pela especificação de conversão atual.
- Um modificador de comprimento opcional que especifica o tamanho do argumento de recebimento.
- Um especificador de formato de conversão.
Especificador de formato Descrição % Corresponde ao% literal c Corresponde a um único caractere ou a vários caracteres. Se a largura for definida, corresponde exatamente aos caracteres de largura. s Corresponde a caracteres consecutivos sem espaço em branco. Se a largura for definida, corresponde exatamente aos caracteres da largura ou até que o primeiro espaço em branco seja encontrado. (conjunto) Corresponde a uma sequência não vazia de caracteres de um determinado conjunto de caracteres. Se estiver presente no início do conjunto, todos os caracteres que não estiverem no conjunto serão correspondidos. d Corresponde a um número inteiro decimal. Eu Corresponde a um número inteiro. o Corresponde a um inteiro octal sem sinal. X ou x Corresponde a um inteiro hexadecimal sem sinal. você Corresponde a um inteiro decimal sem sinal. A ou a, E ou e, F ou f, G ou g Corresponde a um número de ponto flutuante. n Retorna o número de caracteres lidos até agora. p Corresponde a uma sequência de caracteres definida pela implementação que define um ponteiro.
Portanto, o formato geral do especificador de formato é:Especificador% (*) (largura) (comprimento)
- …: Outros argumentos adicionais para receber dados. Eles ocorrem em uma sequência de acordo com o especificador de formato.
swscanf () Valor de retorno
- A função swscanf () retorna o número de argumentos recebidos atribuídos com sucesso.
- Se a falha ocorrer antes de o primeiro argumento de recebimento ser atribuído, EOF será retornado.
Exemplo: Como funciona a função 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 você executa o programa, uma possível saída será:
θ é Theta