一道看似简单却易错的C语言的main函数的参数题目(海康威视的面试题)

本文主要是介绍一道看似简单却易错的C语言的main函数的参数题目(海康威视的面试题),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一道海康的面试题,C语言的main函数有几个参数(多选)

A:argc
B:envp
C:main
D:argv

正确答案是:ABD 

一般情况下,我们会认为是只有两个参数,因为从我们从第一次接触,基本看到的就一直是int argc,char *argv[]这样的形参,第一个参数argc是整型变量,第二个参数argv是指向字符串的指针数组,当然main函数也可以不写参数,这种情况比较少。

那么从实际给出的答案中,我们知道实际情况是还有一个指向环境变量的指针数组char *envp[] 

我们先来看下 int argc 这个我们知道,是统计命令行参数的个数:

#include <stdio.h>int main(int argc, char *argv[])
{printf("参数个数:%d\n", argc);for (int i = 0; i < argc; i++){printf("%s\n", argv[i]);}return 0;
}

 Windows环境:

>gcc test.c -o test
>test Hello China Great
参数个数:4
test
Hello
China
Great

Linux环境:

$ gcc test.c -o test
$ ./test Hello China Great
参数个数:4
./test
Hello
China
Great

可以看到上述的程序名test也当作了一个参数,所以我们获取参数,最好下面这样写:

#include <stdio.h>int main(int argc, char *argv[])
{while (argc-- > 1){printf("%s\n", *++argv);}return 0;
}

前面两个参数大家熟悉了,重点来看下环境变量envp这个指针数组,正确的写法如下:

#include <stdio.h>int main(int argc, char *argv[], char *envp[])
{int i = 0;while (envp[i]){printf("%s\n", envp[i++]);}return 0;
}

重新编译之后,Win和Linux中的截图如下:

可以看到显示了本地的环境变量,每个字符指针指向一条环境变量。

我们来了解下,这个main函数是怎么被调用的,首先会在加载时,启动一个_start函数,这个函数调用_libc_start_main函数,再去调用main函数的,也就是说,真正的入口函数应该是main被调用前的两个函数。
_start函数的作用主要就是调用__stack_init来初始化堆栈,调用__data_init来初始化全局变量,以及main函数和__exit_program退出程序,将控制权交给操作系统。
那么这个_libc_start_main也是程序入口,怎么理解呢?这个_start函数一般是在汇编中定义,操作系统加载程序的时候,控制权就交给_start函数,而_libc_start_main是C标准库中定义的(glibc),作用也是做一些初始化工作和调用main函数,这个函数是有编译器自动调用,跟程序员无关。
所以这里,我们来看下_libc_start_main函数的源码,当然这个内部函数跟操作系统和编译器有很大关系,代码大概如下:

int _libc_start_main(int (*main)(int, char**, char**), void (*exit)(void), void (*abort)(void), char** environ, void (*h)(void (*)(void)), void (*h_rt)(void (*)(void)), void (*thread_detach)(void)) {// 初始化C库libc_init();// 用户的main函数int result = main(argc, argv, environ);// 清理工作libc_cleanup();// 返回main函数结果return result;
}

这里我们可以看到,main函数的参数是三个,类型分别是int, char**, char**,函数体重自定义的main函数三个形参名称为argc, argv, environ,其中environ就是指向环境变量的指针数组,这样就解释了,main函数本质上是三个参数。
我们也可以看到一道看似简单的面试题,也可以引申出操作系统对于如何加载C程序的一些扩展知识。

这篇关于一道看似简单却易错的C语言的main函数的参数题目(海康威视的面试题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/247481

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

4B参数秒杀GPT-3.5:MiniCPM 3.0惊艳登场!

​ 面壁智能 在 AI 的世界里,总有那么几个时刻让人惊叹不已。面壁智能推出的 MiniCPM 3.0,这个仅有4B参数的"小钢炮",正在以惊人的实力挑战着 GPT-3.5 这个曾经的AI巨人。 MiniCPM 3.0 MiniCPM 3.0 MiniCPM 3.0 目前的主要功能有: 长上下文功能:原生支持 32k 上下文长度,性能完美。我们引入了

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直