繁体   English   中英

函数C mysql的隐式声明

[英]implicit declaration of function C mysql

typedef struct database
{
    char *host;
    char *user;
    char *pass;
    char *name;

    MYSQL *mysql;
    MYSQL_RES *result;
    MYSQL_ROW row;
}database_t;
extern database_t db;

........................

MYSQL* mysql_connection_setup(database_t db)
{   
    //MYSQL *connect = mysql_init(NULL);
    db.mysql = mysql_init(NULL);

    printf("HOST %s\n", db.host);
    if(!mysql_real_connect(db.mysql, db.host, db.user, db.pass, db.name, 0, 0, 0)) 
    {
        printf("Conection error : %s\n", mysql_error(db.mysql));
        exit(1);
    }
    return db.mysql;
}

MYSQL_RES* mysql_perform_query(MYSQL *connect, char *command)
{
    if(mysql_query(connect, command))
    {
        printf("MySQL query error : %s\n", mysql_error(connect));
        exit(1);
    }

    return mysql_use_result(connect);
}

.........................

如果我尝试在中使用mysql函数

int some_func()
{
  database_t *db = malloc(sizeof(database_t));
  db->mysql = mysql_connection_setup();
  return 0;
}

编译后,请参阅一些警告。

警告:函数'mysql_connection_setup'的隐式声明[-Wimplicit-function-declaration] db-> mysql = mysql_connection_setup(); 警告:赋值使指针从整数开始而没有强制转换[-Wint-conversion] db-> mysql = mysql_connection_setup();

我怎么办呢?

警告说,当您初次使用mysql_connection_setup()时,编译器未看到任何声明。 因此,编译器隐式声明了一个int返回类型,该类型与您的实际函数冲突。 (请注意,自C99以来,“隐式int”规则已从C标准中删除)。

因此,在源文件的顶部提供一个声明:

MYSQL* mysql_connection_setup(database_t db);

或者,如果在其他源文件中使用mysql_connection_setup()则在头文件中将其声明为extern并将其包含在源文件中。

con_setup.h:

#ifndef CON_SETUP_H
#define CON_SETUP_H

extern MYSQL* mysql_connection_setup(database_t db);

#endif

并在C文件中包含con_setup.h

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM