c语言gcc main的声明报错,《C语言 — 隐式函数声明implicit declaration 》

1. 隐式函数声明概念

在C语言中,函数在调用前不一定非要声明。如果没有声明,那么编译器会自动按照一种隐式声明的规则,为调用函数的C代码产生汇编代码。下面是一个例子:

int main(int argc, char** argv)

{

double x = any_name_function();

return 0;

}

单纯的编译上述源代码,并没有任何报错,只是在链接阶段因为找不到名为any_name_function的函数体而报错。

[smstong@centos192 test]$ gcc -c main.c

[smstong@centos192 test]$ gcc main.o

main.o: In function `main':

main.c:(.text+0x15): undefined reference to `any_name_function'(`any_name_function'引用没有定义)

collect2: ld 返回 1

之所以编译不会报错,是因为C语言规定,对于没有声明的函数,自动使用隐式声明。相当于变成了如下代码:

int any_name_function();

int main(int argc, char** argv)

{

double x = any_name_function();

return 0;

}

2.程序中造成的问题

前面给出的例子,并不会造成太大影响,因为在链接阶段很容易发现存在的问题。然而下面这个例子则会造成莫名的运行时错误。

#include

int main(int argc, char** argv)

{

double x = sqrt(1);

printf("%lf", x);

return 0;

}

gcc编译链接

[smstong@centos192 test]$ gcc -c main.c

main.c: 在函数‘main’中:

main.c:6: 警告:隐式声明与内建函数‘sqrt’不兼容

[smstong@centos192 test]$ gcc main.o

运行结果

1.000000

编译时会给出警告,提示隐式声明与内建函数’sqrt’不兼容。gcc编译器在编译时能够自动在常用库头文件(内建函数)中查找与隐式声明同名的函数,如果发现两者并不相同,则会按照内建函数的声明原型去生成调用代码。这往往也是程序员预期的想法。

上面的例子中隐式声明的函数原型为:

int sqrt(int);

而对应的同名内建函数原型为:

double sqrt(double);

最终编译器按照内建函数原型进行了编译,达到了预期效果。然而gcc编译器的这种行为并不是C语言的规范,并不是所有的编译器实现都有这样的功能。

3.隐式声明函数名称恰好在链接库中存在,且返回int类型

标签:function,gcc,int,C语言,declaration,main,声明,隐式

来源: https://www.cnblogs.com/zhuangquan/p/11757879.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在C语言中使用SQLite3,你需要安装SQLite3库,并使用gcc编译器进行编译。下面是一些基本的步骤: 1. 首先,确保你的系统已经安装了SQLite3库。如果没有安装,可以通过以下命令在Ubuntu上进行安装: ``` sudo apt-get install libsqlite3-dev ``` 如果你使用的是其他Linux发行版或者操作系统,可以根据对应的包管理器进行安装。 2. 创建一个新的C文件,比如"main.c",并在文件中包含SQLite3的头文件: ```c #include <stdio.h> #include <sqlite3.h> ``` 3. 在C文件中编写SQLite3的相关代码。这里是一个简单的例子,演示了如何打开一个数据库、创建表、插入数据和关闭数据库: ```c int main() { sqlite3 *db; char *error_message = 0; int rc = sqlite3_open("example.db", &db); if (rc != SQLITE_OK) { printf("无法打开数据库: %s\n", sqlite3_errmsg(db)); return 1; } char *sql = "CREATE TABLE IF NOT EXISTS MyTable (id INTEGER PRIMARY KEY, name TEXT);" "INSERT INTO MyTable (id, name) VALUES (1, 'John');" "INSERT INTO MyTable (id, name) VALUES (2, 'Jane');"; rc = sqlite3_exec(db, sql, 0, 0, &error_message); if (rc != SQLITE_OK) { printf("SQL执行误: %s\n", error_message); sqlite3_free(error_message); } else { printf("数据插入成功!\n"); } sqlite3_close(db); return 0; } ``` 4. 使用gcc编译器进行编译。在终端中,使用以下命令: ``` gcc main.c -o main -lsqlite3 ``` 这将生成一个可执行文件"main"。 5. 运行可执行文件: ``` ./main ``` 如果一切顺利,你将看到输出结果,并创建一个名为"example.db"的SQLite数据库文件。 请注意,以上只是SQLite3的基本用法示例。你可以根据自己的需求进一步探索和使用SQLite3的其他功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值