C6067
Aviso C6067: parâmetro <number> na chamada para <function> deve ser o endereço da seqüência de caracteres
Este aviso indica uma incompatibilidade entre o especificador de formato e o parâmetro de função. Mesmo que o aviso sugere usando o endereço da seqüência de caracteres, você deve verificar o tipo do parâmetro de que uma função de espera antes de corrigir o problema. Por exemplo, um %s especificação para printf requer um argumento de seqüência de caracteres, mas um %s especificação em scanf requer um endereço da seqüência de caracteres.
Esse defeito é a probabilidade de causar uma pane ou a corrupção de alguma forma.
Exemplo
O código a seguir gera este aviso porque um número inteiro é passado em vez de uma seqüência de caracteres:
#include <stdio.h>
void f_defective( )
{
char *str = "Hello, World!";
printf("String:\n %s",1); // warning
// code ...
}
Para corrigir o aviso, passar uma seqüência como um parâmetro para printf conforme mostrado no código a seguir:
#include <stdio.h>
void f_corrected( )
{
char *str = "Hello, World!";
printf("String:\n %s",str);
// code ...
}
O código a seguir gera este aviso porque um nível incorreto de indireção é especificado quando o parâmetro buffer para scanf:
#include <stdio.h>
void h_defective( )
{
int retval;
char* buffer = new char(20);
if ( buffer )
{
retval = scanf("%s", &buffer); // warning C6067
// code...
delete buffer ;
}
}
Para corrigir acima avisos, passe o parâmetro correto, conforme mostrado no código a seguir:
#include <stdio.h>
void h_corrected( )
{
int retval;
char* buffer = new char(20);
if ( buffer )
{
retval = scanf("%s", buffer);
// code...
delete buffer;
}
}
O código a seguir usa as funções de manipulação de cadeia de caracteres seguras para corrigir este aviso:
#include <stdio.h>
void f_safe( )
{
char buff[20];
int retVal;
sprintf_s( buff, 20, "%s %s", "Hello", "World!" );
printf_s( "String:\n %s %s", "Hello", "World!" );
retVal = scanf_s("%s", buff, 20);
}
Consulte também
Referência
sprintf_s, _sprintf_s_l, swprintf_s, _swprintf_s_l