计算机面试题汇总C语言.docx

上传人:b****4 文档编号:3755314 上传时间:2022-11-25 格式:DOCX 页数:36 大小:30.31KB
下载 相关 举报
计算机面试题汇总C语言.docx_第1页
第1页 / 共36页
计算机面试题汇总C语言.docx_第2页
第2页 / 共36页
计算机面试题汇总C语言.docx_第3页
第3页 / 共36页
计算机面试题汇总C语言.docx_第4页
第4页 / 共36页
计算机面试题汇总C语言.docx_第5页
第5页 / 共36页
点击查看更多>>
下载资源
资源描述

计算机面试题汇总C语言.docx

《计算机面试题汇总C语言.docx》由会员分享,可在线阅读,更多相关《计算机面试题汇总C语言.docx(36页珍藏版)》请在冰豆网上搜索。

计算机面试题汇总C语言.docx

计算机面试题汇总C语言

计算机面试题汇总-C语言

*static有什么用途?

(请至少说明两种)

 限制变量的作用域

 设置变量的存储域

 

*全局变量和局部变量在内存中是否有区别?

如果有,是什么区别?

 全局变量储存在静态数据区,局部变量在栈

 

*堆栈溢出一般是由什么原因导致的?

 没有回收垃圾资源

 

*写出floatx与“零值”比较的if语句。

 if(x>0.000001&&x<-0.000001)

 

*局部变量能否和全局变量重名?

 答:

能,局部会屏蔽全局。

要用全局变量,需要使用":

:

"

 局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。

对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内

 

*不能做switch()的参数类型是:

 switch的参数不能为实型。

 

*如何引用一个已经定义过的全局变量?

 答:

extern

 可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个变量写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错

 

*全局变量可不可以定义在可被多个.C文件包含的头文件中?

为什么?

 答:

可以,在不同的C文件中以static形式来声明同名全局变量。

 可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错

 

*语句for(;1;)有什么问题?

它是什么意思?

 答:

和while

(1)相同。

 

*5、do……while和while……do有什么区别?

 答:

前一个循环一遍再判断,后一个判断以后再循环

 

*请写出下列代码的输出内容

#include

main()

{

 inta,b,c,d;

 a=10;

 b=a++;

 c=++a;

 d=10*a++;

 printf("b,c,d:

%d,%d,%d",b,c,d);

 return0;

}

 答:

b,c,d:

10,12,120

 

*static全局变量与普通的全局变量有什么区别?

static局部变量和普通局部变量有什么区别?

static函数与普通函数有什么区别?

 全局变量(外部变量)的说明之前再冠以static就构成了静态的全局变量。

全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。

这两者在存储方式上并无不同。

这两者的区别虽在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。

而静态全局变量则限制了其作用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文件中不能使用它。

由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。

 从以上分析可以看出,把局部变量改变为静态变量后是改变了它的存储方式即改变了它的生存期。

把全局变量改变为静态变量后是改变了它的作用域,限制了它的使用范围。

 static函数与普通函数作用域不同。

仅在本文件。

只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义。

对于可在当前源文件以外使用的函数,应该在一个头文件中说明,要使用这些函数的源文件要包含这个头文件

 static普通的全局变量有什么全局变量与区别:

static全局变量只初使化一次,防止在其他文件单元中被引用;

 static局部变量和普通局部变量有什么区别:

static局部变量只被初始化一次,下一次依据上一次结果值;

 static函数与普通函数有什么区别:

static函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝(这一点是针对C++的)

 

*程序的局部变量存在于(堆栈)中,全局变量存在于(静态区)中,动态申请数据存在于(堆)中。

 

*设有以下说明和定义:

typedefunion{longi;intk[5];charc;}DATE;

structdata{intcat;DATEcow;doubledog;}too;

DATEmax;

则语句printf("%d",sizeof(structdate)+sizeof(max));的执行结果是:

___52____

 答:

DATE是一个union,变量公用空间.里面最大的变量类型是int[5],占用20个字节.所以它的大小是20

 data是一个struct,每个变量分开占用空间.依次为int4+DATE20+double8=32.

 所以结果是20+32=52.

 当然...在某些16位编辑器下,int可能是2字节,那么结果是int2+DATE10+double8=20

 

*写出下列代码的输出内容

#include

intinc(inta)

{

 return(++a);

}

intmulti(int*a,int*b,int*c)

{

 return(*c=*a**b);

}

typedefint(FUNC1)(intin);

typedefint(FUNC2)(int*,int*,int*);

 

voidshow(FUNC2fun,intarg1,int*arg2)

{

 INCp=&inc;

 inttemp=p(arg1);

 fun(&temp,&arg1,arg2);

 printf("%d\n",*arg2);

}

 

main()

{

 inta;

 show(multi,10,&a);

 return0;

}

 答:

110

 

*请找出下面代码中的所以错误

 说明:

以下代码是把一个字符串倒序,如“abcd”倒序后变为“dcba”

 

1、#include"string.h"

2、main()

3、{

4、 char*src="hello,world";

5、 char*dest=NULL;

6、 intlen=strlen(src);

7、 dest=(char*)malloc(len);

8、 char*d=dest;

9、 char*s=src[len]; 

10、while(len--!

=0)

11、 d++=s--;

12、printf("%s",dest);

13、return0;

14、}

答:

方法1:

intmain(){

 char*src="hello,world";

 intlen=strlen(src);

 char*dest=(char*)malloc(len+1);//要为\0分配一个空间

 char*d=dest;

 char*s=&src[len-1];//指向最后一个字符

 while(len--!

=0)

 *d++=*s--;

 *d =0;//尾部要加\0

 printf("%s\n",dest);

 free(dest);//使用完,应当释放空间,以免造成内存汇泄露

 return0;

}

方法2:

#include

#include

main()

{

 charstr[]="hello,world";

 intlen=strlen(str);

 chart;

 for(inti=0;i

 t=str[i];

 str[i]=str[len-i-1];

 str[len-i-1]=t;

 }

 printf("%s",str);

 return0;

}

 

*在c语言库函数中将一个字符转换成整型的函数是atool()吗,这个函数的原型是什么?

 函数名:

atol

 功 能:

把字符串转换成长整型数

 用 法:

longatol(constchar*nptr);

程序例:

#include

#include

intmain(void)

{

 longl;

 char*str="98765432";

 l=atol(str);

 printf("string=%sinteger=%ld\n",str,l);

 return(0);

}

 

*对于一个频繁使用的短小函数,在C语言中应用什么实现,在C++中应用什么实现?

 c用宏定义,c++用inline

 

*enumstring{

   x1,

   x2,

   x3=10,

   x4,

   x5,}x;

 问x4=11,x1=0;

 

*unsignedchar*p1;

 unsignedlong*p2;

 p1=(unsignedchar*)0x801000;

 p2=(unsignedlong*)0x810000;

请问p1+5=0x801005;

    p2+5=0x810014;

 

*找错题:

 1.请问下面程序有什么错误?

  inta[60][250][1000],i,j,k;

  for(k=0;k<=1000;k++)

   for(j=0;j<250;j++)

    for(i=0;i<60;i++)

     a[i][j][k]=0;

 答:

for(k=0;k<=1000;k++)超界,应为k<1000

 2.#defineMax_CB500

   voidLmiQueryCSmd(StructMSgCB*pmsg)

   {

    unsignedcharucCmdNum;

    ......

  

    for(ucCmdNum=0;ucCmdNum

    {

     ......;

    }

   }

 答:

Struct改成struct,另外,ucCmdNum最大数256<500。

  3.以下是求一个数的平方的程序,请找出错误:

   #defineSQUARE(a)((a)*(a))

   inta=5;

   intb;

   b=SQUARE(a++);

 答:

SQUARE(a++)展开后变成((a++)*(a++)).

  4.typedefunsignedcharBYTE

    intexamply_fun(BYTEgt_len;BYTE*gt_code)

     {

      BYTE*gt_buf;

      gt_buf=(BYTE*)MALLOC(Max_GT_Length);

      ......

      if(gt_len>Max_GT_Length)

      {

       returnGT_Length_ERROR;

      }

       .......

     }

 答:

    typedefunsignedcharBYTE

    intexamply_fun(BYTEgt_len;BYTE**gt_code)

     {

      BYTE**gt_buf;

      *gt_buf=(BYTE*)malloc(gt_len);

      ......

      if(gt_len>Max_GT_Length)

      {

       returnGT_Length_ERROR;

      }

       .......

     }

 

*heap与stack的差别。

 heap是堆,stack是栈。

 stack的空间由操作系统自动分配/释放,heap上的空间手动分配/释放。

 stack空间有限,heap是很大的自由存储区

 C中的malloc函数分配的内存空间即在堆上,C++中对应的是new操作符。

 程序在编译期对变量和函数分配内存都在栈上进行,且程序运行过程中函数调用时参数的传递也在栈上进行

*用宏定义写出swap(x,y)

#defineswap(x,y)\

x=x+y;\

y=x-y;\

x=x-y;

 

*2.数组a[N],存放了1至N-1个数,其中某个数重复一次。

写一个函数,找出被重复的数字.时间复杂度必须为o(N)函数原型:

 intdo_dup(inta[],intN)

 

*一语句实现x是否为2的若干次幂的判断

 inti=512;

 cout<

false:

true)<

 

*unsignedintintvert(unsignedintx,intp,intn)实现对x的进行转换,p为起始转化位,n为需要转换的长度,假设起始点在右边。

如x=0b00010001,p=4,n=3转换后x=0b01100001

unsignedintintvert(unsignedintx,intp,intn){

 unsignedint_t=0;

 unsignedint_a=1;

 for(inti=0;i

   _t|=_a;

   _a=_a<<1;

 }

 _t=_t<

 x^=_t;

 returnx;

}

 

*char*constp;

 charconst*p

 constchar*p

 上述三个有什么区别?

char*constp;//常量指针,p的值不可以修改

charconst*p;//指向常量的指针,指向的常量值不可以改

constchar*p;//和charconst*p

 

*main()

{

 inta[5]={1,2,3,4,5};

  int*ptr=(int*)(&a+1);

  printf("%d,%d",*(a+1),*(ptr-1));

}

输出:

2,5

*(a+1)就是a[1],*(ptr-1)就是a[4],执行结果是2,5

&a+1不是首地址+1,系统会认为加一个a数组的偏移,是偏移了一个数组的大小(本例是5个int)

int*ptr=(int*)(&a+1);

则ptr实际是&(a[5]),也就是a+5

原因如下:

&a是数组指针,其类型为int(*)[5];

而指针加1要根据指针类型加上一定的值,

不同类型的指针+1之后增加的大小不同

a是长度为5的int数组指针,所以要加5*sizeof(int)

所以ptr实际是a[5]

但是prt与(&a+1)类型是不一样的(这点很重要)

所以prt-1只会减去sizeof(int*)

a,&a的地址是一样的,但意思不一样,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5].

 

*请问以下代码有什么问题:

intmain()

{

 chara;

 char*str=&a;

 strcpy(str,"hello");

 printf(str);

 return0;

}

没有为str分配内存空间,将会发生异常

问题出在将一个字符串复制进一个字符变量指针所指地址。

虽然可以正确输出结果,但因为越界进行内在读写而导致程序崩溃。

 

char*s="AAA";

printf("%s",s);

s[0]='B';

printf("%s",s);

有什么错?

"AAA"是字符串常量。

s是指针,指向这个字符串常量,所以声明s的时候就有问题。

cosntchar*s="AAA";

然后又因为是常量,所以对是s[0]的赋值操作是不合法的。

 

*写一个“标准”宏,这个宏输入两个参数并返回较小的一个。

 #defineMin(X,Y)((X)>(Y)?

(Y):

(X))

 

*嵌入式系统中经常要用到无限循环,你怎么用C编写死循环。

 while

(1){}或者for(;;)

 

*关键字static的作用是什么?

 定义静态变量

 

*关键字const有什么含意?

 表示常量不可以修改的变量。

 

*关键字volatile有什么含意?

并举出三个不同的例子?

 提示编译器对象的值可能在编译器未监测到的情况下改变。

 

*int(*s[10])(int)表示的是什么啊

 int(*s[10])(int)函数指针数组,每个指针指向一个intfunc(intparam)的函数。

 

*有以下表达式:

inta=248,b=4;

intconstc=21;

constint*d=&a;

int*conste=&b;

intconst*fconst=&a;

请问下列表达式哪些会被编译器禁止?

为什么?

*c=32;d=&b;*d=43;e=34;e=&a;f=0x321f;

*c这是个什么东东,禁止

*d说了是const,禁止

e=&a说了是const禁止

const*fconst=&a;禁止

 

*交换两个变量的值,不使用第三个变量。

即a=3,b=5,交换之后a=5,b=3;

有两种解法,一种用算术算法,一种用^(异或)

a=a+b;

b=a-b;

a=a-b;

or

a=a^b;//只能对int,char..

b=a^b;

a=a^b;

or

a^=b^=a^=b;

 

*

#include

#include

voidgetmemory(char*p)

{

   p=(char*)malloc(100);

   strcpy(p,"helloworld");

}

intmain()

{

   char*str=NULL;

   getmemory(str);

   printf("%s/n",str);

   free(str);

   return0;

}

程序崩溃,getmemory中的malloc不能返回动态内存,free()对str操作很危险

 

*charszstr[10];

 strcpy(szstr,"0123456789");

 产生什么结果?

为什么?

 超界,长度不一样,会造成非法的OS

 

*(void*)ptr和(*(void**))ptr的结果是否相同?

其中ptr为同一个指针

 (void*)ptr和(*(void**))ptr值是相同的

 

*intmain()

 {

   intx=3;

   printf("%d",x);

   return1;

  }

 问函数既然不会被其它函数调用,为什么要返回1?

 mian中,c标准认为0表示成功,非0表示错误。

具体的值是某种具体出错信息

 

*要对绝对地址0x100000赋值,我们可以用

  (unsignedint*)0x100000=1234;

 那么要是想让程序跳转到绝对地址是0x100000去执行,应该怎么做?

  *((void(*)())0x100000)();

首先要将0x100000强制转换成函数指针,即:

(void(*)())0x100000

然后再调用它:

*((void(*)())0x100000)();

用typedef可以看得更直观些:

typedefvoid(*)()voidFuncPtr;

*((voidFuncPtr)0x100000)();

 

*已知一个数组table,用一个宏定义,求出数据的元素个数

 #defineNTBL(sizeof(table)/sizeof(table[0]))

 

*unsignedshortA=10;

 printf("~A=%u\n",~A);

 charc=128;

 printf("c=%d\n",c);

输出多少?

并分析过程

第一题,~A=0xfffffff5,int值为-11,但输出的是uint。

所以输出4294967285

第二题,c=0x10,输出的是int,最高位为1,是负数,所以它的值就是0x00的补码就是128,所以输出-128。

这两道题都是在考察二进制向int或uint转换时的最高位处理。

 

*分析下面的程序:

voidGetMemory(char**p,intnum)

{

   *p=(char*)malloc(num);

}      

intmain()

{

   char*str=NULL;

   GetMemory(&str,100);

   strcpy(str,"hello");

   free(str);

  

   if(str!

=NULL){

       strcpy(str,"world");

   }  

   printf("\nstris%s",str);

   getchar();

}

问输出结果是什么?

希望大家能说说原因,先谢谢了

输出strisworld。

free只是释放的str指向的内存空间,它本身的值还是存在的.

所以free之后,有一个好的习惯就是将str=NULL.

此时str指向空间的内存已被回收,如果输出语句之前还存在分配空间的操作的话,这段存储空间是可能被重新分配给其他变量的,

尽管这段程序确实是存在大大的问题(上面各位已经说得很清楚了),但是通常会打印出world来。

这是因为,进程中的内存管理一般不是由操作系统完成的,而是由库函数自己完成的。

当你malloc一块内存的时候,管理库向操作系统申请一块空间(可能会比你申请的大一些),然后在这块空间中记录一些管理信息(一般是在你申请的内存前面一点),并将可用内存的地址返回。

但是释放内存的时候,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 求职职场 > 简历

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1