没有合适的资源?快使用搜索试试~ 我知道了~
首页[面试/笔试系列3]局部变量能否和全局变量重名
1、局部变量能否和全局变量重名? 答:能,局部会屏蔽全局。要用全局变量,需要使用"::" ; 局部变量可以与全局变量同名, 在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器 而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名 的局部变量,而那个局部变量的作用域就在那个循环体内。 2、如何引用一个已经定义过的全局变量? 答:extern 可以用引用头文件的方式,也可以用extern 关键字,如果用引用头文件方式 来引用某个在头文件中声明的全局变理,假定你将那个编写错了,那么在编译期间会报错, 如果你用extern 方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连 接期间报错。
资源详情
资源评论
资源推荐
1、局部变量能否和全局变量重名?
答:能,局部会屏蔽全局。要用全局变量,需要使用"::" ;局部变量可以与全局变量同名,
在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器
而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名
的局部变量,而那个局部变量的作用域就在那个循环体内。
2、如何引用一个已经定义过的全局变量?
答:extern 可以用引用头文件的方式,也可以用 extern 关键字,如果用引用头文件方式
来引用某个在头文件中声明的全局变理,假定你将那个编写错了,那么在编译期间会报错,
如果你用 extern 方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连
接期间报错。
3、全局变量可不可以定义在可被多个.C 文件包含的头文件中?为什么?
答:可以,在不同的 C 文件中以 static 形式来声明同名全局变量。 可以在不同的 C 文
件中声明同名的全局变量,前提是其中只能有一个 C 文件中对此变量赋初值,此时连接不
会出错.
4、请写出下列代码的输出内容
#include <stdio.h>
int main(void)
{
int a,b,c,d;
a=10;
b=a++;
c=++a;
d=10*a++;
printf("b,c,d:%d,%d,%d",b,c,d);
return 0;
}
答:10,12,120
5、static 全局变量与普通的全局变量有什么区别?static 局部变量和普通局部变量有什么区
别?static 函数与普通函数有什么区别?
答:1) 全局变量(外部变量)的说明之前再冠以 static 就构成了静态的全局变量。全局变量本
身就是静态存储方式, 静态全局变量当然也是静态存储方式。 这两者在存储方式上并无不
同。这两者的区别在于非静态全局变量的作用域是整个源程序, 当一个源程序由多个源文
件组成时,非静态的全局变量在各个源文件中都是有效的。 而静态全局变量则限制了其作
用域, 即只在定义该变量的源文件内有效, 在同一源程序的其它源文件中不能使用它。由
于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用, 因此可以
避免在其它源文件中引起错误。
2) 从以上分析可以看出, 把局部变量改变为静态变量后是改变了它的存储方式即改变了它
的生存期。把全局变量改变为静态变量后是改变了它的作用域,限制了它的使用范
围。 3) static 函数与普通函数作用域不同,仅在本文件。只在当前源文件中
使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义。对于可
在当前源文件以外使用的函数,应该在一个头文件中说明,要使用这些函数的源文件要包含
这个头文件
综上所述:
static 全局变量与普通的全局变量有什么区别:
static 全局变量只初使化一次,防止在其他文件单元中被引用;
static 局部变量和普通局部变量有什么区别:
static 局部变量只被初始化一次,下一次依据上一次结果值;
static 函数与普通函数有什么区别:
static 函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝
6、程序的局部变量存在于(堆栈)中,全局变量存在于(静态区 )中,动态申请数据存
在于( 堆)中。
7、设有以下说明和定义:
typedef union
{
long i;
int k[5];
char c;
} DATE;
struct data
{
int cat;
DATE cow;
double dog;
} too;
DATE max;
则语句 printf("%d",sizeof(struct data)+sizeof(max));的执行结果是:___52____
考点:区别 struct 与 union.(一般假定在 32 位机器上)
答:DATE 是一个 union, 变量公用空间. 里面最大的变量类型是 int[5], 占用 20 个字节. 所
以它的大小是 20. data 是一个 struct, 每个变量分开占用空间. 依次为 int4 + DATE20 +
double8 = 32. 所以结果是 20 + 32 = 52. 当然...在某些 16 位编辑器下,int可能是 2 字节,
那么结果是 int2 + DATE10 + double8 = 20
8、队列和栈有什么区别?
队列先进先出,栈后进先出
9、写出下列代码的输出内容
#include <stdio.h>
int inc(int a)
{ return(++a); }
int multi(int*a,int*b,int*c)
{ return(*c=*a**b); }
typedef int(FUNC1)(int in);
typedef int(FUNC2) (int*,int*,int*);
void show(FUNC2 fun,int arg1, int*arg2)
{
FUNC1 p=&inc;
int temp =p(arg1);
fun(&temp,&arg1, arg2);
printf("%dn",*arg2);
}
main()
{
int a; //局部变量 a 为 0;
show(multi,10,&a);
return 0;
}
答:110
10、请找出下面代码中的所有错误 (题目不错,值得一看)
说明:以下代码是把一个字符串倒序,如“abcd”倒序后变为“dcba”
#include"string.h"
main()
{
char*src="hello,world";
char* dest=NULL;
int len=strlen(src);
dest=(char*)malloc(len);
char* d=dest;
char* s=src[len];
while(len--!=0)
d++=s--;
printf("%s",dest);
return 0;
}
答:
方法 1:一共有 4 个错误;
int main()
{
char* src = "hello,world";
int len = strlen(src);
char* dest = (char*)malloc(len+1);//要为分配一个空间 char* d = dest;
char* s = &src[len-1]; //指向最后一个字符
while( len-- != 0 )
*d++=*s--;
*d = 0; //尾部要加’\0’
printf("%sn",dest);
free(dest); // 使用完,应当释放空间,以免造成内存汇泄露
dest = NULL; //防止产生野指针
return 0;
}
方法 2: (方法一需要额外的存储空间,效率不高.) 不错的想法
#include <stdio.h>
#include <string.h>
main()
{
char str[]="hello,world";
int len=strlen(str);
char t;
for(int i=0; i<len/2; i++)
{
t=str[i];
str[i]=str[len-i-1]; //小心一点
str[len-i-1]=t;
}
printf("%s",str);
return 0;
}
11.对于一个频繁使用的短小函数,在 C 语言中应用什么实现,在 C++中应用什么实现?
c 用宏定义,c++用 inline
12.直接链接两个信令点的一组链路称作什么?
PPP 点到点连接
13.接入网用的是什么接口?
V5 接口
14.voip 都用了那些协议?
H.323 协议簇、SIP 协议、Skype 协议、H.248 和 MGCP 协议
15.软件测试都有那些种类?
黑盒:针对系统功能的测试
白盒:测试函数功能,各函数接口
16.确定模块的功能和模块的接口是在软件设计的那个队段完成的?
概要设计阶段
17.
unsigned char *p1;
unsigned long *p2;
p1=(unsigned char *)0x801000;
p2=(unsigned long *)0x810000;
请问 p1+5= ;
p2+5= ;
答案:0x801005(相当于加上 5 位) 0x810014(相当于加上 20 位);
选择题:
21.Ethternet 链接到 Internet 用到以下那个协议?D
A.HDLC;B.ARP;C.UDP;D.TCP;E.ID
22.属于网络层协议的是:( B C)
A.TCP;B.IP;C.ICMP;D.X.25
23.Windows 消息调度机制是:(C)
A.指令队列;B.指令堆栈;C.消息队列;D.消息堆栈;
找错题:
25.请问下面程序有什么错误?
int a[60][250][1000],i,j,k;
for(k=0;kMax_GT_Length)
剩余58页未读,继续阅读
Jake443403168
- 粉丝: 47
- 资源: 395
上传资源 快速赚钱
- 我的内容管理 收起
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
会员权益专享
最新资源
- RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz
- c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf
- 建筑供配电系统相关课件.pptx
- 企业管理规章制度及管理模式.doc
- vb打开摄像头.doc
- 云计算-可信计算中认证协议改进方案.pdf
- [详细完整版]单片机编程4.ppt
- c语言常用算法.pdf
- c++经典程序代码大全.pdf
- 单片机数字时钟资料.doc
- 11项目管理前沿1.0.pptx
- 基于ssm的“魅力”繁峙宣传网站的设计与实现论文.doc
- 智慧交通综合解决方案.pptx
- 建筑防潮设计-PowerPointPresentati.pptx
- SPC统计过程控制程序.pptx
- SPC统计方法基础知识.pptx
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论4