C语言基础面试题

合集下载

c语言面试经常问的问题C语言面试题

c语言面试经常问的问题C语言面试题

c语言面试经常问的问题C语言面试题C语言面试题篇11、已知字母b的ASCII码的十进制代码为98,则执行下列语句输出为(C)ch=’b’;ch–;printf(%d,%c\n”,ch,ch);A)a,bB)运算不合法,故有语法错C)97,aD)格式描述和输出项不匹配,输出无值2、若变量a已说明为float类型,则能实现将a中的数值保留小数点后两位,第三位进行四舍五入运算的表达式是(C)A)a=(a某100+0.5)/100.0B)a=(a某100+0.5)/100C)a=(int)(a某100+0.5)/100D)a=(a/100+0.5)某100.03、下列程序段的输出结果是(B)inta=5,b=7;printf(“%d,%d”,a++,++b);A)5,7B)5,8C)6,7D)6,8C语言面试题篇21、下列程序的输出结果是(D){inta=4;a某=a+=6;printf(“%d\n”,a);}A)40B)60C)80D)1002、下列程序的输出结果是(C)main(){inta=8;printf(“%a”,(a=a某5,a+6));}A)14B)40C)46D)50C语言面试题篇31、定义a为整型,下列表达式a=3>6的运行后,a的值为(A)A)0B)1C)3D)表达式错误2、、如果a=1,b=2,c=3,d=4,则条件表达式a>ba:c>dc:d的值为(D)A)1B)2C)3D)43、下述程序段的输出结果是(A){inta=5;printf(“%d,”,a);a+=a某=a-=a某=2;printf(“%d”,a);}A)5,0B)0,0C)5,12D)0,124、下列变量名中合法的是(A)A)TomB)3a6bC)6a7bD)5ABC5、对于条件表达式(M)(a++):(a–),其中的表达式M等价于(C)A)M==0B)M==1C)M!=0D)m!=1。

16道c语言面试题

16道c语言面试题

16道c语言面试题C语言面试题在C语言的学习过程中,面试题是一个非常重要的环节。

无论是应聘工作还是进入高校深造,掌握面试题的解答技巧都能给我们带来巨大的优势。

下面,我将为大家总结并解答一些常见的C语言面试题,希望对大家的面试准备有所帮助。

1. 请解释一下什么是C语言?C语言是一种通用的高级编程语言,由Dennis M. Ritchie于1972年在贝尔实验室开发。

它被广泛应用于系统软件、应用软件和嵌入式系统的开发中。

2. 请说出C语言的特点。

C语言具有以下几个特点:- 简洁高效:C语言设计简洁,只包含少量的关键字和语法规则,编写出的代码效率高。

- 面向过程:C语言注重问题的解决过程,强调按照步骤编写程序。

- 低级语言特性:C语言提供了丰富的指针操作功能,能够直接访问内存地址,灵活性高。

- 可移植性:C语言的源代码可以在不同的机器上进行编译和执行。

- 强大的库支持:C语言有丰富的函数库,便于程序员快速开发各种功能。

3. 请解释一下变量和常量的区别。

变量是用来存储数据的一种容器,可以根据需要改变存储的内容。

而常量是指在程序中固定不变的值,一旦定义就不能修改。

4. 什么是指针?指针是一个变量,其值为内存地址。

通过指针,我们可以直接访问内存中的数据。

5. 请解释一下数组和指针之间的关系。

数组名本身也是一个指针,它存储了数组的首地址。

利用指针可以对数组进行遍历和操作。

6. 请示范一下C语言中定义和打印字符串的方法。

在C语言中,字符串可以通过字符数组表示。

定义方法如下:```char str[20] = "Hello, World!";```打印字符串的方法如下:```printf("%s", str);```7. 什么是函数?函数是C语言中的一段可重复使用的代码,用于完成特定的任务。

函数可以接收参数和返回值。

8. 怎样定义一个函数?函数的定义包括函数的返回类型、函数名、参数列表和函数体。

c与c_面试题目(3篇)

c与c_面试题目(3篇)

第1篇第一部分:C语言基础1. 面试题:请解释C语言中的“变量声明”和“变量定义”的区别。

解析:- 变量声明:告诉编译器即将使用一个变量,但不分配存储空间。

它只告诉编译器变量的名称、数据类型和存储类别。

- 变量定义:不仅告诉编译器变量的名称、数据类型和存储类别,还分配存储空间给变量。

```cint i; // 变量声明int i = 10; // 变量定义```2. 面试题:什么是内存泄漏?如何检测和避免内存泄漏?解析:- 内存泄漏:在程序运行过程中,由于疏忽或错误,导致已分配的内存没有被释放,导致内存占用逐渐增加,最终可能耗尽系统内存。

- 检测内存泄漏:可以使用工具如Valgrind、Sanitizer等来检测内存泄漏。

- 避免内存泄漏:- 确保所有分配的内存在使用后都被释放。

- 使用智能指针(如C++中的`std::unique_ptr`、`std::shared_ptr`)来自动管理内存。

```cvoid function() {int ptr = malloc(sizeof(int)); // 分配内存// 使用ptr...free(ptr); // 释放内存}```3. 面试题:请解释C语言中的指针和数组的关系。

解析:- 在C语言中,数组名本身就是一个指向数组首元素的指针。

- 可以通过指针访问数组元素,也可以通过数组下标访问。

```cint arr[10];int ptr = arr; // ptr指向数组的第一个元素int value = (ptr + 5); // 访问数组中索引为5的元素```4. 面试题:请解释C语言中的结构体(struct)和联合体(union)的区别。

解析:- 结构体:可以包含不同数据类型的成员,每个成员都有自己的内存空间。

- 联合体:所有成员共享同一块内存空间,在某一时刻只有一个成员有效。

```cstruct {int a;float b;} s;union {int a;float b;} u;```第二部分:C++基础1. 面试题:请解释C++中的构造函数和析构函数。

c的面试题及答案

c的面试题及答案

c的面试题及答案面试题一:请解释一下C语言的指针和引用的区别。

答案:在C语言中,指针和引用都是用来处理内存地址的。

它们的主要区别在于以下几个方面:1. 定义和使用方式:- 指针是一个变量,存储的是一个内存地址。

通过使用"*"操作符可以获取或修改该地址对应的值。

- 引用则是一个已存在对象的别名。

它在定义时需要和原对象进行绑定,并且无法更改绑定的对象。

2. 空指针和无效引用:- 指针可以被赋值为空指针(NULL)或无效的地址值,表示指针不指向任何有效的内存地址。

- 引用必须在定义时进行初始化,并且必须引用一个有效的对象。

3. 内存管理:- 指针需要显式地通过动态内存分配函数(如malloc())进行内存的分配和释放。

- 引用的内存管理则由编译器自动处理,无需手动管理。

4. 数组和函数的传递:- 指针可以用于处理数组或者作为函数的参数进行传递。

- 引用可以作为函数参数,但无法直接用于处理数组。

面试题二:请解释C语言中的堆和栈的区别。

答案:在C语言中,堆和栈是两种不同的内存分配方式,具有以下区别:1. 分配方式:- 栈是由编译器自动分配和释放的,它的空间有限,大小在编译时就已经确定。

- 堆是由程序员手动分配和释放的,它的空间相比栈更大,并且大小在运行时可动态调整。

2. 内存结构:- 栈的数据结构为“先进后出”的方式,即后进栈的数据先出栈。

- 堆则没有明确的数据结构,按照动态分配顺序分配内存。

3. 分配效率:- 栈的分配和释放速度要快于堆,因为栈只需要移动栈顶指针即可。

- 堆的分配和释放速度相对较慢,因为需要在运行时进行内存的动态分配和回收。

4. 使用方式:- 栈主要用于存储局部变量、函数调用和函数参数等数据。

- 堆主要用于存储动态分配的内存,如通过malloc()函数分配的内存块。

面试题三:请解释C语言中的宏定义和常量的区别。

答案:在C语言中,宏定义和常量都可以用来表示不可更改的值,但它们的区别如下:1. 定义方式:- 宏定义使用“#define”关键字进行定义,没有数据类型限制。

应届生c语言面试题

应届生c语言面试题

应届生c语言面试题
以下是一些可能的应届生C语言面试题:
1. C语言有哪些数据类型?
2. C语言中如何定义变量?
3. C语言中什么是常量?
4. 什么是函数?如何定义一个函数?
5. 函数的返回值是什么?
6. 什么是传值调用和传址调用?
7. 什么是数组?如何定义一个数组?
8. 什么是字符串?如何定义一个字符串?
9. 什么是结构体?如何定义一个结构体?
10. 什么是联合体?如何定义一个联合体?
11. C语言中的指针是什么?如何声明和使用指针变量?
12. 什么是递归函数?如何实现递归函数?
13. C语言中如何实现文件操作?
14. C语言中如何进行内存管理?
15. C语言中什么是预处理器指令?include和define的作用是什么?
16. C语言中什么是位运算?有哪些位运算符?
17. C语言中什么是条件编译?有哪些条件编译指令?
18. C语言中什么是枚举类型?如何定义枚举类型?
19. C语言中什么是强制类型转换?如何进行强制类型转换?
20. 描述一下C语言的内存布局,包括代码区、数据区和堆区。

以上是一些可能的面试题,当然,具体的面试题目会根据具体的公司和职位而有所不同。

在面试之前,你可以通过查阅相关资料和做练习题来准备这些面试题。

C语言面试题

C语言面试题

C语言面试题一、C语言面试题:1、问:在嵌入式开发中,为什么能通过C语言直接操作硬件?答:因为C有指针,它是C语言的灵魂,它可以直接访问内存。

2、问:链表的作用?(这是上一个问题的延申,学员一般会举一堆例子来说明它的作用,但这都不是重点,没有抓住主要矛盾)答:链表用于内存管理,链表节点中的指针域可以将不连续的内存彼此关联起来,实现内存的动态管理。

3、问:什么变量不能用指针指向?答:寄存器变量(register 修饰),因为这个变量会优先选择存放到CPU寄存器中,而指针只能指向内存的任务区域,但不能指向寄存器。

4、问:有符号字符型和无符号字符型变量的最大值和最小值分别是多少(十六进制多少),为什么?答:有符号(-128—127,-0X80—0X7F),无符号(0-255,0X00—0XFF)。

5、问:林锐面试题中四个有关内存操作的问题:第一题、运行会出现段错误(崩溃):答:因为参数是值传递,所以主调函数中的str指针已然指向空,不能向里面拷数据,除非加上取地址,采用二维指针接收才能传递动态内存;第二题:乱码:答:实际上可能是乱码,也可能显示出一部分内容,显示乱码是因为刚才那段栈内存空间全部被覆盖,如果未完全覆盖则显示一部分内容;第三题:能够输出hello答:但由于没有在同一层释放内存,容易导致内存泄露;第四题:对已经释放的内存进行操作答:会破坏其它有用数据,后果难以预料,通常提示出现段错误。

6、问:哪些地方可以用到const?const变量和函数输入参数用const修饰有哪些作用?答:1、定义常量(1)const修饰变量,const TYPE ValueName=value;value是不可变的。

(2)将const 改为外部链接,作用于扩大至全局,编译时分配内存,并且可以不进行初始化,仅仅作为声明,编译器认为在在程序其他地方进行了定义;Extend const int ValueName = value;2、指针使用CONST(1)指针本身是常量不可变(char *)const pContent;Const (char*)pContent;(2)指针指向的内容是常量不可变Const char *pContent;Char const *pContent;(3)两者都不可变Const char *const pConten3、函数中使用CONST(1)const修饰函数的参数a 传递过来的参数在函数内不可以改变;void function(const int var);b 参数指针所指内容为常量不可变;void function(const char *Var);c 参数本身为常量不可变;void function(char *const Var);二、系统编程1、问:什么是程序?什么是进程?本质区别?答:程序是存放在磁盘上一些指令的有序集合;进程是程序执行的实例,是个动态的过程;本质区别:程序是静态的,进程是动态的。

C语言基础面试题

C语言基础面试题

1 源程序的编译及链接是怎样一个过程?如下图所示:2编写第一个简单的C语言程序3 C语言是强类型的语言,这是什么意思?任何程序都要处理数据,计算机可以处理的数据有多种类型。

在C语言程序中,用来保存数据的变量必须事先定义才能在程序中使用。

定义变量的语法如下:变量类型名变量名表;例如,以下语句定义了x、y、z三个变量名,其值只能取整型值:int x,y,z;在C程序中,每一个变量都必须声明其取值类型。

因此,C语言是一种强类型的程序设计语言。

对于程序中使用到的常量、变量的类型要事先进行定义才能使用,这是保证程序可靠性的手段之一。

早期的一些计算机程序设计语言不要求对变量的类型进行定义,因此,一个变量的类型在程序运行期间是不确定的,这将会降低程序的可靠性。

4 如何理解变量与常量?变量与常量相当于数据的可读可写与只读,常量是数据的一种保护机制。

在内存分配给程序的内存块中有专门的常量(只读)存储区。

5 如何正确理解和使用赋值运算符?赋值运算符“=”连接的是左边的变量和右边的表达式,把表达式的值赋值给左边的变量。

赋值运算符的优先级比较低,只在逗号运算符之前。

一个赋值表达式中可以包含多个赋值表达式,赋值表达式的值就等于左边变量的值,在不加圆括号的情况下,赋值运算符按“从右至左”的结合顺序运算。

由于赋值运算符的优先级比较低,如果出现在其他表达式中需要优先运算,则要加圆括号。

赋值运算符“=”连接的是左边的变量和右边的表达式,当变量和表达式的数据类型不一致时,会产生什么样的结果?C语言赋予了赋值表达式类型转换的功能,一旦出现变量和表达式的数据类型不一致的情况,会自动进行类型的转换,将表达式的值向变量类型的方向进行转换。

当然,也不是所有不匹配的类型都可以转换,类型转换有一定的前提,必须是相近的、可以转换的类型才能进行转换。

6 为什么表达式1/2的值为0?在以下的代码段中,变量x的值为0:float x;x=1/2;变量x虽然被定义为单精度浮点型,但以上代码执行后,x的取值为0,而不是0.5。

c语言面试题目100及最佳答案

c语言面试题目100及最佳答案

c语言面试题目100及最佳答案作为IT行业人士需要掌握的最基本的计算机语言—c语言,如今的地位只高不低,c语言掌握程度的高低往往在面试的时候可以完全表现出来,而有些问题是大家平时似乎是知道的,但却不能完整准确地回答上来的,今天大家带来精心整理的C语言经典面试题,希望对大家有所帮助.1、请填写bool , float, 指针变量与“零值”比较的if语句。

提示:这里“零值”可以是0, 0。

0 , FALSE 或者“空指针”。

例如int 变量n 与“零值”比较的if 语句为:if ( n == 0 )if ( n != 0 )以此类推。

(1)请写出bool flag 与“零值”比较的if 语句:【标准答案】if ( flag ) if ( !flag )100 条经典 C语言笔试题目(2)请写出float x 与“零值"比较的if 语句:【标准答案】 const float EPSINON = 0.00001;if ((x 〉= - EPSINON) &&(x <= EPSINON)不可将浮点变量用“==" 或“!=" 与数字比较,应该设法转化成“〉=”或“〈=”此类形式。

100 条经典 C语言笔试题目(3)请写出char *p 与“零值"比较的if 语句【标准答案】 if (p == NULL) if (p != NULL)2、以下为Linux下的32 位C 程序,请计算sizeof 的值。

char str[] = “Hello”;char *p = str ;i nt n = 10;请计算(1)sizeof (str ) = (2)s i zeof ( p ) = (3)sizeof ( n ) =【标准答案】(1)6、(2)4 、(3 )4(4)void Func ( char str[100]){……;}请计算sizeof( str ) =(5)void * p = mall oc( 100 );请计算sizeof ( p ) =【标准答案】(4)4、(5)44、用变量a 给出下面的定义e) 一个有10个指针的数组,该指针是指向一个整型数的;f) 一个指向有10个整型数数组的指针;g)一个指向函数的指针,该函数有一个整型参数并返回一个整型数;h) 一个有10个指针的数组,该指针指向一个函数,该函数有一个整型参数并返回一个整型数;【标准答案】e)int * a[10]; f)int (*a)[10]g)int (*a)(int); h) int (*a[10])(int)5、设有以下说明和定义:typedef u nion {long i; int k[5]; char c;} DATE;struct data { int cat; DATE cow; double dog;} too; DATE max;则语句printf("%d",sizeof(struct date)+sizeof(max));的执行结果是:_____【标准答案】DATE是一个union,变量公用空间。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

1:设float a=2, b=4, c=3;,以下C语言表达式与代数式(a+b)+c计算结果不一致的是
A.(a+b)*c/2
B.(1/2)*(a+b)*c
C.(a+b)*c*1/2
D.c/2*(a+b)
参考答案:B,因为a,b,c三个变量都是浮点数,所以在B答案中其结果是0,因为在计算1/2是就是0,如果改成1/2.0就正确了。

2:为了向二进制文件尾部增加数据,打开文件的方式应采用
A.″ab″
B.″rb+″
C.″wb″
D.″wb+″
参考答案:D
3:下述程序执行后的输出结果是
#include
main()
{
int x='f';
printf("%c\n",'a'+(x-'a'+1));
}
A.g
B.h
C.i
D.j
参考答案:A
4:C语言中,下列运算符优先级最高的是
A.!
B.%
C.>>
D.==
参考答案:A
5:数组定义为“ int a [ 4 ] ; ”,表达式( ) 是错误的。

A.*a
B.a [ 0 ]
C.a
D.a++
参考答案:D
6:执行语句“ k=7>>1; ”后,变量k 的当前值是
A.15
B.31
C.3
D.1
参考答案:C
7:定义函数时,缺省函数的类型声明,则函数类型取缺省类型
A.void
B.char
C.float
D.int
参考答案:D
8:若main()函数带参数,参数个数最多是
A.0
B.1
C.2
D.3
参考答案:C 只知道有定义形式main(int argc,char* argv[]))
9:若有宏定义:#define MOD(x,y) x%y 则执行以下语句后的输出结果是
int a=13,b=94;
printf(″%d\n″,MOD(b,a+4));
A.5
B.7
C.9
D.11
参考答案:B
10:下列各个错误中,哪一个不属于编译错误
A.改变x 原值3 为5 ,写作“ x==5 ;”
B.花括号不配对
C.复合语句中的最后一条语句后未加分号
D.变量有引用、无定义
参考答案:A
11:下列程序段运行后,x 的值是( )
a=1;b=2;x=0;
if(!( -- a))x -- ;
if(!b)x=7;else ++x;
A.0
B.3
C.6
D.7
参考答案:A
12:设
#define N 3
#define Y(n) ((N+1)*n)
则表达式2*(N+Y(5+1))的值是
A.42
B.48
C.54
D.出错
参考答案:B Y(5+1) 传递过去的应该是6,而不是简单的把5+1给替换掉
13:若定义了char ch[]={″abc\0def″},*p=ch;则执行printf(″%c″,*p+4);语句的输出结果是
A.def
B.d
C.e
D.0
参考答案:C
14:下列转义字符中错误的是
A.′\000′
B.′\14′
C.′\x111′
D.′\2′
参考答案:C error C2022: '273' : too big for character
15:算术运算符,赋值运算符和关系运算符的运算优先级按从高到低依次为
A.算术运算、赋值运算、关系运算
B.算术运算、关系运算、赋值运算
C.关系运算、赋值运算、算术运算
D.关系运算、算术运算、赋值运算
参考答案:B
16:设#define N 3
#define Y(n) ((N+1)*n)
则表达式2*(N+Y(5+1))的值是
A.42
B.48
C.54
D.出错
参考答案:B
17:表达式strcmp( “ 3.14 ”,“ 3.278 ” ) 的值是一个
A.非零整数
B.浮点数
C.0
D.字符
参考答案:A
18:设struct
{ short a;
char b;
float c;
}cs;
则sizeof(cs)的值是
A.4
B.5
C.6
D.7
参考答案:D 字节对齐的话应该是8
19:若变量已正确定义,表达式( j=3 ,j++ )的值是
A.3
B.4
C.5
D.0
参考答案:A
20:C 语言中运算对象必须是整型的运算符是
A.%
B./
C.!
D.**
参考答案:A
简答题
21:打印一个N*N的方阵,N为每边字符的个数(3〈N〈20 ),要求最外层为“X”,第二层为“Y”,从第三层起每层依次打印数字0,1,2,3,...
例子:当N =5,打印出下面的图形:
X X X X X
X Y Y Y X
X Y 0 Y X
X Y Y Y X
X X X X X
22:谈谈COM的线程模型。

然后讨论进程内/外组件的差别。

23:多态类中的虚函数表是Compile-Time,还是Run-Time时建立的?
参考答案:
虚拟函数表是在编译期就建立了,各个虚拟函数这时被组织成了一个虚拟函数的入口地址的数组.
而对象的隐藏成员--虚拟函数表指针是在运行期--也就是构造函数被调用时进行初始化的,这是实现多态的关键.
24:#include
void main()
{ int c;
while ((c=getchar())!= ′\ n ′ )
switch(c - ′ 2 ′ )
{ case 0:
case 1:putchar(c+4);break;
case 2:putchar(c+4);break;
case 3:putchar(c+3);break;
default:putchar(c+2);break;
}
printf( ″\ n ″ );
}
运行时输入:2473 ,输出结果:
参考答案:6897 VC++6.0测试过
25:用两个栈实现一个队列的功能?
参考答案:
设2个栈为A,B, 一开始均为空.入队:
将新元素push入栈A;出队:
(1)判断栈B是否为空;
(2)如果不为空,则将栈A中所有元素依次pop出并push到栈B;
(3)将栈B的栈顶元素pop出;这样实现的队列入队和出队的平摊复杂度都还是O(1),
26:写一语句实现x是否为2的若干次幂的判断。

参考答案:!(X)&(X-1)
27:解二次方程:a*x*x+b*x+c
int Quadratic( double a,double b,double c,double& x1,double& x2);
返回值:解的个数
28:如何判别一个数是unsigned。

参考答案;
#define issignal(x) ((x>=0 && ~x>=0) ? 1:0) //为1是无符号为0有符号
29:执行下述程序的输出结果是 ABCDEFCDEFEF 。

#include
char b[]="ABCDEF";
main()
{
char *bp;
for (bp=b;*bp;bp+=2)
printf("%s",bp);
printf("\n");
}
30:已知一个数组table,用一个宏定义,求出数据的元素个数。

参考答案:#define NTBL
#define NTBL (sizeof(table)/sizeof(table[0]))。

相关文档
最新文档