A função vsscanf () em C ++ é usada para ler os dados de um buffer de string.
A função vsscanf () é definida no arquivo de cabeçalho.
protótipo vsscanf ()
int vsscanf (const char * buffer, const char * formato, va_list vlist);
A função vsscanf () lê os dados do buffer de string de caracteres e armazena os valores nos respectivos locais, conforme definido por vlist.
Parâmetros vsscanf ()
- 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, vsscanf () não atribui o resultado a nenhum argumento de recebimento.
- Um número inteiro positivo opcional que especifica a largura máxima do campo. Ele especifica o número máximo de caracteres que vsscanf () 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)
- vlist: uma lista de argumentos para receber as entradas.
vsscanf () Valor de retorno
- Se for bem-sucedido, a função vsscanf () retorna o número de argumentos lidos com sucesso.
- Em caso de falha, EOF é retornado.
Exemplo: Como funciona a função vsscanf ()?
#include #include void read(const char* buf, const char * format,… ) ( va_list args; va_start (args, format); vsscanf (buf, format, args); va_end (args); ) int main () ( char buffer(100) = "Bruce Wayne Batman"; char fname(20), lname(20), superhero(20); read(buffer, "%s %s %s", fname, lname, superhero); printf("%s %s is %s.", fname, lname, superhero); return 0; )
Quando você executa o programa, uma possível saída será:
Bruce Wayne é o Batman.