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 $?
参考资料
- C89 https://www.gwduan.com/web/computer/languages/c/c89_en.html
- C99 https://www.gwduan.com/web/computer/languages/c/c99.pdf
- C11 https://web.cs.dal.ca/~vlado/pl/C_Standard_2011-n1570.pdf
- C17 https://files.lhmouse.com/standards/ISO C N2176.pdf