235 最新百度电面

2019-04-14 22:04发布

35.   2011.10.11 最新百度电面:
1、动态链接库与静态链接库的区别        静态链接库是.lib 格式的文件,一般在工程的设置界面加入工程中,程序编译时会把 lib 文件的代码加入你的程序中因此会增加代码大小,你的程序一运行 lib 代码强制被装入你程序的运行空间,不能手动移除 lib 代码。        动态链接库是程序运行时动态装入内存的模块,格式*.dll,在程序运行时可以随意加载和移除,节省内存空间。
       在大型的软件项目中一般要实现很多功能,如果把所有单独的功能写成一个个 lib文件的话,程序运行的时候要占用很大的内存空间,导致运行缓慢;但是如果将功能写成 dll 文件,就可以在用到该功能的时候调用功能对应的 dll 文件,不用这个功能时将dll 文件移除内存,这样可以节省内存空间。 
2、指针与引用的区别 相同点:1.  都是地址的概念;指针指向一块内存,它的内容是所指内存的地址;引用是某块内存的别名。 区别:
1. 指针是一个实体,而引用仅是个别名;
2. 引用使用时无需解引用(*),指针需要解引用;
3. 引用只能在定义时被初始化一次,之后不可变;指针可变;
4. 引用没有 const,指针有 const;
5. 引用不能为空,指针可以为空;
6.  “sizeof 引用”得到的是所指向的变量(对象)的大小,而“sizeof 指针”得到的是指针本身(所指向的变量或对象的地址)的大小;
7. 指针和引用的自增(++)运算意义不一样;
8. 从内存分配上看:程序为指针变量分配内存区域,而引用不需要分配内存区域。 )
3、进程与线程的区别 ①从概念上: 进程:一个程序对一个数据集的动态执行过程,是分配资源的基本单位。
线程:一个进程内的基本调度单位。
线程的划分尺度小于进程,一个进程包含一个或者更多的线程。
②从执行过程中来看:
进程:拥有独立的内存单元,而多个线程共享内存,从而提高了应用程序的运行效率。
线程:每一个独立的线程,都有一个程序运行的入口、顺序执行序列、和程序的出口。
但是线程不能够独立的执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。 
③从逻辑角度来看:(重要区别
多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但是,操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理及资源分配。 )
4、函数调用入栈出栈的过程
        函数调用过程中,第一个进栈的是(主函数中的)调用处的下一条指令(即函数调用语句的下一条可执行语句)的地址;然后是函数的各个参数,而在大多数C/C++编译器中,在函数调用的过程中,函数的参数是由右向左入栈的;然后是函数内部的局部变量(注意static变量是不入栈的);在函数调用结束(函数运行结束)后,局部变量最先出栈,然后是参数,最后栈顶指针指向最开始存的指令地址,程序由该点继续运行。
int a = 1;
printf("%d,%d,%d ", a, a++, a++);
程序输出为:
3, 2, 1
C语言函数参数进栈顺序是自右向左
出栈顺序自左向右 5、c++对象模型与虚表
7、海量数据处理,以及如何解决 Hash 冲突等问题
8、系统设计,概率算法