为什么C语言main函数是int而不是void,为什么要return 0

今天下午java课,杨老师提出一个问题思考,回来之后查询了相关文章,一知半解,记录一下。
为什么C语言main函数是int而不是void
为什么要return 0
首先是浏览众多史书资料,知道一开始的C语言是不限制主函数类型的,一些古早的C语言书籍上也是使用void main() 这种写法的。
几乎所有的CSDN文章(反正我看到的都是一个版本出来的)都引用了C++之父Bjarne Stroustrup主页上的FAQ的内容。

The definition void main( ) { /* … */ } is not and never has been C++, nor has it even been C.

找了半天,找到了这段的出处。中文互联网可以搜到
Bjarne Stroustrup的主页(这里直接跳到void main 这一段了)

相关描述
可见确实void main()的不合法地位是被C++之父坐实的。

下面根据一个例子可以更好理解为什么放弃使用void和为什么要return 0

需要进到linux系统进行。

vim a.c
a.c文件

#include<stdio.h>
int main()
{
        printf("You jump!\n");
        return  0;
}

gcc -o a a.c
输出为
a输出

更换return 后面的数字,单独运行a结果不变。
接着vim b.c
b.c文件

#include<stdio.h>
int main()
{
        printf("I jump!\n");
        return  0;
}

gcc -o b b.c

两个程序一起运行:

&& 的含义是:如果 && 前面的程序正常退出,则继续执行 && 后面的程序,否则不执行 。

二人幸终
可以看到两个人都跳下去了。

这时候修改 a.c

#include<stdio.h>
int main()
{
        printf("You jump!\n");
        return 2;
}

编译再一起运行看看呢:
你人呢?为什么不跳!
发现当a的return不为0的时候,后续的程序无法运行。

所以可以推断,return 0 是主函数运行完毕的标志,如果不返回0(哪怕return ;)操作系统都无法判断其是否执行完从而进行下一个程序的执行。

这就是return值的必要性。

如果纰漏,望请指正,共同学习。

这篇文章对我启发很大,感谢作者在无数同质文章中能让我眼前一亮!

  • 10
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
在主函数中调用单链表,需要先定义并初始化一个链表的头节点。然后根据需要,逐个插入节点,构建链表的过程。可以使用一个循环,不断地通过用户输入或其他方式获取节点的值,并将新节点插入到链表的尾部。 典型的、简单的调用单链表的主函数如下所示: ```C++ #include <iostream> using namespace std; // 定义单链表的节点结构 struct ListNode { int val; // 节点的值 ListNode* next; // 指向下一个节点的指针 ListNode(int x) : val(x), next(NULL) {} // 构造函数 }; // 构建单链表 ListNode* buildLinkedList() { ListNode* head = new ListNode(0); // 头节点 ListNode* p = head; // 当前节点 int n; // 用于记录节点的值 cout << "请输入节点的值 (输入 0 结束):" << endl; cin >> n; while (n != 0) { ListNode* newNode = new ListNode(n); // 新建节点 p->next = newNode; // 将新节点连接到当前节点的后面 p = p->next; // 更新当前节点为新节点 cout << "请输入节点的值 (输入 0 结束):" << endl; cin >> n; } return head->next; // 返回链表的首节点 } // 打印链表 void printLinkedList(ListNode* head) { ListNode* p = head; cout << "链表的值为: "; while (p != NULL) { cout << p->val << " "; p = p->next; } cout << endl; } int main() { ListNode* head = buildLinkedList(); // 构建链表 printLinkedList(head); // 打印链表 return 0; } ``` 以上代码定义了一个用于构建单链表和打印链表的函数,分别为`buildLinkedList`和`printLinkedList`。在主函数中,先调用`buildLinkedList`函数构建链表,然后再调用`printLinkedList`函数打印链表的值。 运行该程序,用户可以根据提示输入节点的值,直到输入0为止,构建完成后将会显示链表的值。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值