|
|
C语言面试题集
( W+ L/ ]/ O" R- B
1 G" S) f# Y9 F, W5 f: h4 |. M1 Z 1. 关键字static有什么用途?(请至少说明两种)
# ~% @* T. u# T, z 1.限制变量的作用域2.设置变量的存储域5 R4 `1 U8 {2 k& d
; U& m' N; j" ~5 U* P1 N2 A- s
2. 引用与指针有什么区别?# A' Z+ d3 }6 n, k
1) 引用必须被初始化,指针不必。) X# v6 U1 Z( e- o5 a: P
2) 引用初始化以后不能被改变,指针可以改变所指的对象。
1 R5 m% l% G, x. h1 ]4 @% J" |2) 不存在指向空值的引用,但是存在指向空值的指针。NULL
X8 M2 I: o( @* _
4 H( P$ z$ o8 i ?$ A" A# w0 R% E, h 3. 描述实时系统的基本特性
$ J) f2 W/ `) K, G& q在特定时间内完成特定的任务,实时性与可靠性
W" b; C8 ~, a' ?" \6 ^' J" X' q$ y: Q- i- v
5. 什么是平衡二叉树?& ?% U; @" B" [! F$ X* _/ j; B6 w
左右子树都是平衡二叉树 且左右子树的深度差值的绝对值不大于10 B" E( K* r. V; J
/ i9 O9 R H3 ^5 d, y 6. 堆栈溢出一般是由什么原因导致的?
5 P( c& \3 m: X没有回收垃圾资源
. ], [% F6 Y9 g4 V7 Q
1 T2 ~0 Y' g! @: M [ Q 7. 什么函数不能声明为虚函数?1 N3 _ L, t, P/ _% t) @. O, @
构造函数,因为它是在对象产生之头被调用的,而虚函数是对象产生之后才起作用的机制,所以声明虚构造函数无意义。
6 b# x6 K0 @6 K$ X% Z' L
/ [* w+ g( q5 p. A 8. 冒泡排序算法的时间复杂度是什么?
3 |2 F- x* S( H6 M% F2 N- aO(n^2)
! g" d" u# S1 W5 U4 m! Y9 D" Y0 v% Z
9 写出float x 与“零值”比较的if语句。+ s8 h* r) H4 ~5 O
if(x>0.000001&&x<-0.000001)//见高质量C++编程一书. D* m! y5 k& @' k
! M! O1 D$ R4 Z% D5 I
10. Internet采用哪种网络协议?该协议的主要层次结构?
* b- N+ ^% H; Z" Y- ]tcp/ip 应用层/传输层/网络层/链路层
7 H3 o" ]; H# L8 O; S" w0 K1 W4 S# Q# K, u) W
11. Internet物理地址和IP地址转换采用什么协议?
, S4 v0 w7 N+ T5 ?ARP (Address Resolution Protocol )
& _! K" z5 N4 P/ n% `) W# R* U0 o7 Y9 W6 E, p, ~1 j
12. IP地址的编码分为哪俩部分?/ \2 e$ [% ^) ^
IP地址由两部分组成,网络号和主机号。不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。
- L" U! I6 J3 E# a* {# H6 Z+ z8 P* y" K% M* ?9 v. d: |0 v# M
13. 不能做switch()的参数类型是:
$ B; K. ~- Z9 O. V实型。' J4 S0 I) K& e
" A6 H6 ^# J; ?; W! ^
/ g! R/ N2 O# `" L/ r7 s
14、局部变量能否和全局变量重名?
: r. R" |" `8 {7 J: Y' ?! y答:能,局部会屏蔽全局。要用全局变量,需要使用"::"
- q n. H" l; Z2 m ]8 K; w8 d局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内$ }) g& i2 [$ k5 ~6 b0 J, Q O
7 F/ v% C& r% {9 e7 l) f2 J
15、如何引用一个已经定义过的全局变量?
0 Y& z: b) e/ |# I答:extern关键字; B/ Z6 }# ]9 g/ d/ X9 }0 j
可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个变写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。 @) t6 {' x9 @* P9 z3 b# v
4 b; u v7 H, U e 16、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么?( _6 y, d7 P, s C
答:可以,在不同的C文件中以static形式来声明同名全局变量。6 {- O7 Y/ ]. z% f- P4 i1 j2 Q
可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错; ]9 A# u4 P, r; H- H
0 o* f) Q7 q% \8 d/ f, V9 e
17、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?
3 a1 e/ z5 V6 ?全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。全局变量本身就是静态存储方式, 静态全局变量当然也是静态存储方式。这两者在存储方式上并无不同。这两者的区别虽在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。 而静态全局变量则限制了其作用域, 即只在定义该变量的源文件内有效,在同一源程序的其它源文件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。% G! I( r: A7 y" v. J
从以上分析可以看出, 把局部变量改变为静态变量后是改变了它的存储方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的作用域, 限制了它的使用范围。
: H$ ~. @8 _" q2 w7 f8 C5 jstatic函数与普通函数作用域不同。仅在本文件。只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义。对于可在当前源文件以外使用的函数,应该在一个头文件中说明,要使用这些函数的源文件要包含这个头文件9 S, N/ M% n$ Q2 K$ l4 {% _
! h: {6 _! z7 y2 |$ O6 ostatic全局变量与普通的全局变量有什么区别:static全局变量只初使化一次,防止在其他文件单元中被引用;
2 S- x* O, [( \; o9 ?1 L1 C4 ]static局部变量和普通局部变量有什么区别:static局部变量只被初始化一次,下一次依据上一次结果值;
' h( l% C/ Z1 h' t: xstatic函数与普通函数有什么区别:static函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝" N+ e! K3 c! v$ G2 D
程序的局部变量存在于(栈)中,全局变量存在于(静态区)中,动态申请数据存在于(堆)中。* I! |# V& S- p% g2 c) c
0 ^8 u) ^, k/ |5 R4 f) Q; A" Q
18、设有以下说明和定义:$ C* B S @3 o
typedef union {long i; int k[5]; char c;} DATE;
% u1 E0 ]4 A- H+ w4 [+ U Cstruct data { int cat; DATE cow; double dog;} too;
6 E8 J- f: S5 y: r$ ^; Q5 Y' ^3 MDATE max;
, l' P5 U/ @4 I( Q5 Z1 D1 y5 z# {: w: P则语句 printf("%d",sizeof(struct date)+sizeof(max));的执行结果是:
3 ?8 D5 t7 ?# |2 y5 M% b' _答:
* i, A' K+ k6 j* l16位编译器中,union = 5*2 = 10' ?* F% R1 K5 u+ W
data = int 2 + 10 + 8 = 20
* l. [0 d% b$ m 此时结果为30
& p2 ?. L' G& y+ }0 A& h0 k32位编译器中:union = 5*4 = 20 L3 E/ a8 z( ? F0 Z
Data = int 4+ union 20 + double 8 = 32
8 x; |1 j5 g I$ i: Y 此时结果为52
1 `" v' z0 [' f0 q) Q8 V) a: u/ [1 \2 E5 b% o
…………2 A. v/ y- R1 p) D+ K( G; x
更过相关专业面试经验下载,请关注:http://bbs.aftjob.com/group-348-1.html2 }) D8 v* B$ \
4 r% k; ]# t) o4 k Zzz 文章转摘自网络% Q T# Z: s" y. y" r! e. @
6 p& H) g& w2 T5 H! o2 {
, i& Q$ K/ e! Y0 L4 H' z
6 r0 ?8 R ?$ W: b6 J关注最新求职动态,分享最新求职进度,免费专业团队修改简历,关注你的企业动态,下载最新企业2012求职手册。请留意:http://www.aftjob.com/personal.php! ]+ k) t' l. X7 [" g2 H5 q( s
6 y" ]# S' q. l! E, C( B: N
阿凡提求职交流群,申请加入时请注明学校和姓名,谢谢!
: a: b' L% P/ p1.2012-金融求职交流③:95371773
. n- n: N* t2 X: ]( U6 |. ? 2012-金融求职交流④:95371919
7 \- u5 P3 Q2 H, a& J. S2.2012-会计求职交流①:7098899: x7 @1 ]7 ~" h N% u
2012-会计求职交流③:21754384
6 p9 @2 F7 d# l6 e! G: g" A5 `; w# ~ 2012-会计求职交流②:1289940. r; f+ t2 y/ p
3.2012-IT求职交流③:1289905+ U; W1 d: W2 a) p4 t" |
2012-IT求职交流④:94628451# Z D8 m7 O. _5 u
4.2012-通信求职交流③:95372037
+ _' T1 `0 W! s5.2012-硬件求职交流②:1213195+ e1 L, w. m2 i. V8 L
6.2012-快消求职交流②:713334821 O: E- \% m0 I! l1 F: i. k9 B) `, B
6 L7 {' ^ l* E |
|