LINUXknowledgeWord格式文档下载.docx
- 文档编号:16333143
- 上传时间:2022-11-23
- 格式:DOCX
- 页数:23
- 大小:33.46KB
LINUXknowledgeWord格式文档下载.docx
《LINUXknowledgeWord格式文档下载.docx》由会员分享,可在线阅读,更多相关《LINUXknowledgeWord格式文档下载.docx(23页珍藏版)》请在冰豆网上搜索。
2、-----------------------------------------------------------
下面x,y,*p的值是多少,有什么问题?
intx,y,z=2;
int*p=&
z;
x=sizeof*p;
y=x/*p;
/*x=?
*p=?
y=?
有什么问题?
*/
3、-----------------------------------------------------------
下面的语句是什么意思?
如何声明或定义才使它们更易懂?
(10分)
int(*foo())();
int(*foo())[];
int(*foo[])();
(*(void(*)())0)();
void(*signal(int,void(*)(int)))(int);
4、-----------------------------------------------------------
本题(2分)。
一般使用malloc时,需要进行强制类型转换,如:
char*s;
s=(char*)malloc(31);
下面中?
?
该如何填写,才可以正确执行强制类型转换?
int(*monthp)[31];
monthp=(?
)malloc(31);
5、-----------------------------------------------------------
关于C语言运算符优先级的记忆技巧是什么?
/*下面r的值是多少*/
inthi,low,r;
hi=7;
low=3;
r=hi<
<
4+low;
6、-----------------------------------------------------------
指针和数组的区别是什么?
用一个简单的声明把它们区分开。
指针和数组的声明在什么情况下是相同的?
7、-----------------------------------------------------------
C语言的左值(lvalue)和右值(rvalue)的含义是什么?
8、-----------------------------------------------------------
为什么C语言可以实现printf(char*format,...)这样可变参数的调用形式?
这样有什么缺点?
9、-----------------------------------------------------------
说明C语言中术语"
声明"
定义"
原型"
的含义?
10、-----------------------------------------------------------
举一个例子,说明使用assert和防错代码的区别。
(5分)
11、-----------------------------------------------------------
对语句ifelse与操作符?
:
使用场合的比较。
12、-----------------------------------------------------------
编写一个函数,输入一个的整型数字,可以选择按照8/10/16进制输出字符串。
注意边界值。
13、-----------------------------------------------------------
下面是一个16x16的黑白图标:
staticunsignedshortstopwatch[]={
0x07c6,
0x1ff7,
0x383b,
0x600c,
0xc006,
0xdf06,
0xc106,
0x610c,
0x3838,
0x1ff0,
0x07c0,
0x0000,
};
如何修改声明,可以使之在源代码中形象地表现出图形的模样。
14、-----------------------------------------------------------
说出可以使用calendar[11][30]变量的四种类型定义。
如:
intcalendar[12][31];
/*二维数组*/
15、-----------------------------------------------------------
使用strcmp,当字符串相同时会返回'
\0'
。
但'
一般作为逻辑假,
因此下面的语句不容易理解:
if(!
strcmp(s,"
string"
))returnEQUATION;
如何经过简单修改,使之更易懂?
16、-----------------------------------------------------------
编写一个自己的完全C语言版本的memset函数,并且评价这个实现的性能和可移植性。
(5
分)
17、-----------------------------------------------------------
在树和图这些数据结构中,通常使用指针来组织数据。
如果我们要把这些数据保存到文
件
中,指针是没有意义的。
我们该如何解决这个问题。
18、-----------------------------------------------------------
用2种不同的方法计算long变量的"
1"
bit的个数。
19、-----------------------------------------------------------
任意给出一个C的基本数据类型,如何编码判断这个数据类型是有符号还是无符号的?
(2分)
不得上机实验,写出下面代码的输出。
解释这个行为是标准定义的,还是依赖实现的。
(2分)
inti;
for(i=0;
i<
10;
i++){
intj=i;
printf("
%d\n"
j);
}
20、-----------------------------------------------------------
列出5种以上你所看过的C编程的书籍,并写简要书评。
对C的评价。
如果要你改造一把菜刀,使之更加安全,你是否会使用这样的菜刀,为什么?
一.3、分析题。
本题(各5分)。
假设下面代码中的变量都是合法变量,调用外部的函数都是正确的。
回答几个问题:
这些代码意图要干什么?
是否有问题?
如果有问题,该如何修改,或者如何避免类似错误发生?
如果没有问题,如果代码有输出,输出是什么?
intisvowel(charc)
{
returnc=='
a'
||c=='
e'
i'
o'
u'
;
while(c=='
\t'
||c='
'
\n'
)
c=getc(f);
/*当x=2,y=3,z=?
*/
if(x==0)
if(y==0)
z=-1;
else
z=x+y;
/*处理网络事件*/
voidprocess_network_code(intx,inty)
/*选择modes_pointer资源*/
switch(line){
caseTHING1:
/*处理异常1#,使用老的modes_pointer资源*/
doit1();
break;
caseTHING2:
/*处理异常2#,需要重新启动服务*/
if(x==STUFF){
/*重新申请modes_pointer资源,没有初始化*/
do_first_stuff();
/*在这种条件下,有些资源不用重新申请*/
if(y==OTHER_STUFF)
/*申请剩下的资源,并初始化*/
do_later_stuff();
/*初始化modes_pointer资源*/
initialize_modes_pointer();
default:
/*处理普通事件,使用老的modes_pointer资源*/
processing();
}
/*使用modes_pointer资源,处理事件*/
use_modes_pointer();
intis_gb2312_char(charc1,charc2)
if(c1>
=0xa1&
&
c2>
=0xa1)
return1;
else
return0;
下面x,y的值是多少,有什么问题?
intx=10,y=3;
x^=y;
y^=x;
/*x=?
y=?
intdays[]={31,28,31,30,31,30,31,31,30,31,30,31,};
int*dayp;
memset(calendar,0,sizeof(calendar));
i=0;
for(monthp=calendar;
monthp<
&
calendar[12];
monthp++){
for(dayp=*monthp;
dayp<
(*monthp)[31];
dayp++){
if(dayp-*monthp<
days[calendar-monthp]){
*dayp=i++%7+1;
voidprintnum(longn)
if(n<
0){
putchar('
-'
);
n=-n;
if(n>
=10){
printnum(n/10);
putchar("
0123456789"
[n%10]);
void*memchr(void*pv,unsignedcharch,size_tsize)
unsignedchar*pch=(unsignedchar*)pv;
unsignedchar*pchEnd=pch+size;
while(pch<
pchEnd){
if(*pch==ch)
return(pch);
pch++;
returnNULL;
unsignedchar*pchPlant=pch+size;
unsignedcharchSave=*pchPlant;
*pchPlant=ch;
while(pch!
=ch){
*pchPlant=chSave;
return((pch==pchPlant)?
NULL:
pch);
voidUnsToStr(unsignedshortintu,char*str)
char*pch;
assert(u<
=65535);
pch=&
str[5];
*pch='
do{
*--pch=u%10+'
0'
}while((u/10)>
0);
strcpy(str,pch);
void*memmove(void*pvTo,voidpvFrom,size_tsize)
char*pbTo=(char*)pvTo;
char*pbFrom=(char*)pvFrom;
((pbTo<
pbFrom)?
tailmove:
headmove)(pbTo,pbFrom,size);
return(pvTo);
void*memcpy(void*pvTo,voidpvFrom,size_tsize)
while(size-->
*pbTo++=*pbFrom++;
#include<
stdio.h>
intmain(intargc,char*argv[])
chars[]="
inti=0;
printf("
%c"
i++[s]);
}while(s?
1:
printf("
\n"
)-1);
return0;
intfibonacci(intx)
if(x==1||x==2)
returnfibonacci(x-2)+fibonacci(x-1);
这里有一个程序cdecl.c。
写出它的工作流程。
写出它的使用方法。
给出一个典型输入用例,记录下它的输出。
一.4、综合编程题。
要求:
1、完成需求,程序运行正确。
2、工作原理文档,使用文档完整。
3、代码规整优美。
注释得当。
4、运行速度足够快。
5、用工具分析出是哪些代码或函数造成速度瓶颈。
编写一个排序程序。
被排序的文件有8MB大小,一行一个随机整数(ASCII格式)。
要求对这些整数进行排序,并计算平均值,打印出排序所需的时间。
(20分)
用dummyheader技巧实现一个链表DEMO。
要求具有create,insert,delete,search功能。
编写一个应用程序,使用上面的函数。
使用dummyheader技巧有什么优点。
用heapsort算法实现优先队列。
要求具有create,insert,delete功能。
使用heapsort算法有什么优点。
用trie(一种多叉树)实现一个字典。
使用trie树有什么优点。
二、POSIX方面的知识。
二.1、简答题。
下面的题目必须全部答对才给分:
1、在UNIX环境中,编译流程是什么?
2、ABI,ELF的英文全称是什么
3、一般UNIX的程序有多少段,举一个实际的例子说明。
4、如何在kernel二进制代码中找一个字符串。
5、段地址F000:
FFF0转换为线形地址的值是多少(16进制表达)。
6、在一个UNIX文件系统中,文件的唯一性标志是什么?
二.2、问答题。
写一些代码。
如何用文件实现信号灯?
要求如果程序崩溃了,这个文件也将自动被删除。
为什么可以这样实现信号灯?
传统的signal函数信号处理为什么是不可靠的,信号和系统调用有何关系?
在图形库系统中往往提供timer的功能,除了使用ALARM信号外,你还可以使用什么系统
调用来实现timer?
写
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- LINUXknowledge