欢迎来到天天文库
浏览记录
ID:17386939
大小:216.00 KB
页数:44页
时间:2018-08-30
《软件工程师笔试题目》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、有一个16位的整数,每4位为一个数,写函数求他们的和。解释:整数1101010110110111和1101+0101+1011+0111感觉应该不难,当时对题理解的不是很清楚,所以写了一个函数,也不知道对不对。疑问:既然是16位的整数,1101010110110111是2进制的,那么函数参数怎么定义呢,请大虾指教。答案:用十进制做参数,计算时按二进制考虑。/*n就是16位的数,函数返回它的四个部分之和*/charSumOfQuaters(unsignedshortn){charc=0;inti=4;do{c+=n&15;n=n>>4;}while(--i);returnc;}1。编写
2、一个C函数,该函数在一个字符串中找到可能的最长的子字符串,且该字符串是由同一字符组成的。char*search(char*cpSource,charch){char*cpTemp=NULL,*cpDest=NULL;intiTemp,iCount=0;while(*cpSource){if(*cpSource==ch){iTemp=0;cpTemp=cpSource;while(*cpSource==ch)++iTemp,++cpSource;if(iTemp>iCount)iCount=iTemp,cpDest=cpTemp;if(!*cpSource)break;}++cpSou
3、rce;}returncpDest;}2。请编写一个C函数,该函数在给定的内存区域搜索给定的字符,并返回该字符所在位置索引值。intsearch(char*cpSource,intn,charch){inti;for(i=0;i4、)0x100000然后再调用它:*((void(*)())0x100000)();用typedef可以看得更直观些:typedefvoid(*)()voidFuncPtr;*((voidFuncPtr)0x100000)();2,已知一个数组table,用一个宏定义,求出数据的元素个数#defineNTBL#defineNTBL(sizeof(table)/sizeof(table[0]))unsignedshortA=10;printf("~A=%u",~A);charc=128;printf("c=%d",c);输出多少?并分析过程第一题,~A=0xfffffff5,in5、t值为-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");}print6、f("stris%s",str);getchar();}问输出结果是什么?希望大家能说说原因,先谢谢了输出strisworld。free只是释放的str指向的内存空间,它本身的值还是存在的.所以free之后,有一个好的习惯就是将str=NULL.此时str指向空间的内存已被回收,如果输出语句之前还存在分配空间的操作的话,这段存储空间是可能被重新分配给其他变量的,尽管这段程序确实是存在大大的问题(上面各位已经说得很清楚了),但是通常会打印出world来。这是因为,进程中的内存管理一般不是由操作系统完成的,而是由库函数自己完成的。当你malloc一块内存的时候,管理库向操作系统申请一7、块空间(可能会比你申请的大一些),然后在这块空间中记录一些管理信息(一般是在你申请的内存前面一点),并将可用内存的地址返回。但是释放内存的时候,管理库通常都不会将内存还给操作系统,因此你是可以继续访问这块地址的,只不过。。。。。。。。楼上都说过了,最好别这么干。chara[10],strlen(a)为什么等于15?运行的结果#include"stdio.h"#include"string.h"voidmain(){charaa[10];printf("%d
4、)0x100000然后再调用它:*((void(*)())0x100000)();用typedef可以看得更直观些:typedefvoid(*)()voidFuncPtr;*((voidFuncPtr)0x100000)();2,已知一个数组table,用一个宏定义,求出数据的元素个数#defineNTBL#defineNTBL(sizeof(table)/sizeof(table[0]))unsignedshortA=10;printf("~A=%u",~A);charc=128;printf("c=%d",c);输出多少?并分析过程第一题,~A=0xfffffff5,in
5、t值为-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");}print
6、f("stris%s",str);getchar();}问输出结果是什么?希望大家能说说原因,先谢谢了输出strisworld。free只是释放的str指向的内存空间,它本身的值还是存在的.所以free之后,有一个好的习惯就是将str=NULL.此时str指向空间的内存已被回收,如果输出语句之前还存在分配空间的操作的话,这段存储空间是可能被重新分配给其他变量的,尽管这段程序确实是存在大大的问题(上面各位已经说得很清楚了),但是通常会打印出world来。这是因为,进程中的内存管理一般不是由操作系统完成的,而是由库函数自己完成的。当你malloc一块内存的时候,管理库向操作系统申请一
7、块空间(可能会比你申请的大一些),然后在这块空间中记录一些管理信息(一般是在你申请的内存前面一点),并将可用内存的地址返回。但是释放内存的时候,管理库通常都不会将内存还给操作系统,因此你是可以继续访问这块地址的,只不过。。。。。。。。楼上都说过了,最好别这么干。chara[10],strlen(a)为什么等于15?运行的结果#include"stdio.h"#include"string.h"voidmain(){charaa[10];printf("%d
此文档下载收益归作者所有