优秀的编程知识分享平台

网站首页 > 技术文章 正文

C语言的入口函数

nanyue 2025-01-08 16:18:17 技术文章 5 ℃
int main(int argc,char **argv)
{
  return 0;
}

为什么必须要有且只有一个main函数?

计算机执行程序时,总是要从一个明确的位置开始。通常这个开始位置是约定好的,每一种程序设计语言都会明确定义这个位置,这个位置只能是一个。

基于C语言标准(可参考C99),C语言是通过定义一个固定名字的函数,告诉计算机从这里执行。这个函数就是main,一个可编译、链接执行的项目中只能有一个main函数。

为什么返回值和参数要这样定义?



C语言标准,并没有对实现严格定义main函数的原型,但是给出了建议。建议main函数应该为如下两种形式:

int main(void)
int main(int argc,char **argv)

如果按照第二种方法,main函数就可以获得执行此程序时用户输入参数的个数、程序所在的路径和各个参数具体值。

你可以定义为其他的,编译器一般不会报错误。但是你会因此无法与运行环境适配。例如获得运行环境提供的参数,以及程序执行结束后,运行环境对你运行状态的判定。例如我可以改为如下几种,程序都能编译执行:

float main(int argc,char **argv){return 0.1;}    // 还是可以获得运行参数,但是返回值不被运行环境识别 
void main(void){return}                           // 不能获得运行参数,返回值也不被识别

为什么示例总是要返回0?

符合C语言规范的返回值应该是一个整数。


这个整数,将被运行环境用来判定程序执行的状态。一般0被认为是成功执行了,其他是失败后的错误原因标识。

在ubuntu下,控制台环境bash,通常有三种办法来识别这个值,例如执行完毕后,马上检查环境变量$?;例如在bash脚本通过if直接执行程序,基于程序返回值判定成功与否;命令行直接使用&& ||来基于程序成功与否执行其他命令。

#/user/bin/bash

echo -e "\033[33m Begin to run $1... \033[0m"

CMD="$1 1>/dev/null 2>/dev/null"

# 可以执行程序后,使用 && || 来检查执行成功与否
echo -e "\033[32m 使用&& || 检查执行状态 \033[0m"
$1  1>/dev/null 2>/dev/null && echo "&& ok" || echo "|| nok"

# 可以通过if直接执行程序,并检查返回值是否为0来确认执行成功与否
echo -e "\033[32m 使用f检查执行状态 \033[0m"
if $1  1>/dev/null 2>/dev/null ; then
	echo "if ok"
else
	echo "if nok"
fi


# 可以检查执行后的$? 
echo -e "\033[32m 打印程序返回值 \033[0m"
$1  1>/dev/null 2>/dev/null; echo $?

参考资料

  1. C89 https://www.gwduan.com/web/computer/languages/c/c89_en.html
  2. C99 https://www.gwduan.com/web/computer/languages/c/c99.pdf
  3. C11 https://web.cs.dal.ca/~vlado/pl/C_Standard_2011-n1570.pdf
  4. C17 https://files.lhmouse.com/standards/ISO C N2176.pdf




Tags:

最近发表
标签列表