这两天面试了几个公司,被问到几个问题,而这些问题平时自己没有留意过,都很基础却不会。面试结束及时总结一下,方便以后查询同时也提高自己!
1、linux中的top命令?
top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。
2、linux中要在一个文件a.txt中查找所有出现coffee的地方,用什么命令?
我答的是find,但是忘了find是查找文件的,正确的是grep
3、堆和栈的区别是啥?
一个由C/C++编译的程序占用的内存分为以下几个部分
1、栈区(stack)——由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其
操作方式类似于数据结构中的栈。
2、堆区(heap)
收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表。
3、全局区(静态区)(static)—— 全局变量和静态变量的存储是放在一块的,初始化的
全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另
一块区域。 - 程序结束后由系统释放。
4、文字常量区 —常量字符串就是放在这里的。 程序结束后由系统释放
5、程序代码区—存放函数体的二进制代码。
4、二进制文件与文本文件的区别?
计算机能识别的都是二进制代码,不论是文本文件还是音频视频类的多媒体文件都需要转换成二进制文件,计算机才能识别,这就需要有个转换过程:高级语言→汇编语言→机器语言,计算机只能识别的语言--机器语言。
就讲二进制文件和文本文件的区别的话,二进制文件全都是0和1组成的,而文本文件是由字母、数字、符号等组成。
5、C的文本读写和二进制读写
应该说C的文本读写与二进制的读写是一个编程层次上的问题,与具体的操作系统有关,所以"用文本方
式读写的文件一定是文本文件,用二进制读写的文件一定是二进制文件"这类观点是错误的.下面的讲述非明
确指出操作系统类型,都暗指windows.
C的文本方读写与二进制读写的差别仅仅体现在回车换行符的处理上.文本方式写时,每遇到一
个''\n''(0AH换行符),它将其换成''\r\n''(0D0AH,回车换行),然后再写入文件;当文本读取时,它每遇到一个''\r\n''将其反变化为''\n'',然后送到读缓冲区.正因为文本方式有''\n''--''\r\n''之间的转换,其存在转换耗时.二进制读写时,其不存在任何转换,直接将写缓冲区中数据写入文件.
总地来说,从编程的角度来说,C中文本或二进制读写都是缓冲区与文件中二进制流的交互,只是文本读
写时有回车换行的转换.所以当写缓冲区中无换行符''\n''(0AH),文本写与二进制写的结果是一样的,同理
,当文件中不存在''\r\n''(0DH0AH)时,文本读与二进制读的结果一样。
6、unicode和utf-8的区别
简单来说,unicode,gbk和大五码就是编码的值,而utf-8,uft-16之类就是这个值的表现形式.而前面那三种编码是一兼容的
7、Getmemory的几个经典的关于内存的笔试题
void GetMemory1(char
*p)
{
}
void
Test1(void)
{
}
//GetMemory
并不能传递动态内存, Test 函数中的 str 一直都是 NULL。
/ / strcpy(str, "hello world");将使程序崩溃。
char
*GetMemory2(void)
{
}
void Test2(void)
{
}
//可能是乱码。
/ /因为 GetMemory 返回的是指向“栈内存”的指针,该指针的地址不是 NULL,但其原先的内容已经被清除,新内容不可知。char *GetMemory3(void)
{
}
void Test3(void)
{
}
//Test3 中打印hello world,因为返回常量区,而且并没有被修改过。
void
GetMemory4(char **p, int num)
{
}
void Test4(void)
{
}
//内存没释放
void
Test5(void)
{
{
}
}
//str为野指针,打印的结果不得而知
void
Test6()
{
}
//VC断言失败,运行错误