字节PICO BSP驱动一面凉经
- 进程和线程的区别
- 线程有堆栈空间吗?线程有数据段和代码段吗? 为什么进程切换的花销大
- 线程有独立的栈空间,但是堆空间为整个进程的线程所共享。
- 1.代码段(code segment);2.数据段(data section);3.进程打开的文件描述符;4.信号的处理器;5.进程的当前目录;6.进程用户ID与进程组ID
- 进程切换比线程切换开销大是因为进程切换时要切页表,而且往往伴随着页调度,因为进程的数据段代码段要换出去,以便把将要执行的进程的内容换进来。本来进程的内容就是线程的超集。而且线程只需要保存线程的上下文(相关寄存器状态和栈的信息)就好了,动作很小
- read和f_read区别?
- read不带缓冲区,fread带缓冲区。fread为C库函数,read为UNIX下的系统调用
- read/write是系统调用,要自己分配缓存,也就是说效率要自己根据实际情况来控制。
- fread/fwrite是标准输入/输出函数,不需要自己分配缓存,对于一般情况具有较高的效率。
- 结构体大小计算?
- 1、结构体变量的首地址,必须是结构体变量中的“最大基本数据类型成员所占字节数”的整数倍。(对齐)
- 2、结构体变量中的每个成员相对于结构体首地址的偏移量,都是该成员基本数据类型所占字节的整数倍。(对齐)
- 3、结构体变量的总大小,为结构体变量中“最大基本数据类型成员所占字节数”的整数倍(补齐)
- new和malloc的区别?
- malloc:申请空间需要显式填入申请内存的大小;new:无需显式填入申请的内存大小,new会根据new的类型分配内存。
- new:此操作符分配的内存空间是在自由存储区;malloc:申请的内存是在堆空间。
- new操作符内存分配成功时,返回的是对象类型的指针,类型严格与对象匹配,无须进行类型转换,故new是符合类型安全性的操作符。而malloc内存分配成功则是返回void*,需要通过强制类型转换将void*指针转换成我们需要的类型。
- malloc分配内存失败时返回NULL,我们可以通过判断返回值可以得知是否分配成功;new内存分配失败时,会抛出bac_alloc异常,它不会返回NULL,分配失败时如果不捕捉异常,那么程序就会异常退出,我们可以通过异常捕捉的方式获取该异常。
- malloc:使用malloc分配内存后,发现内存不够用,那我们可以通过realloc函数来扩张内存大小,realloc会先判断当前申请的内存后面是否还有足够的内存空间进行扩张,如果有足够的空间,那么就会往后面继续申请空间,并返回原来的地址指针;否则realloc会在另外有足够大小的内存申请一块空间,并将当前内存空间里的内容拷贝到新的内存空间里,最后返回新的地址指针。new:new没有扩张内存的机制。
- new可以重载,malloc不可以
- new会调用构造函数,malloc不会。
- C++多态?多态一般在什么时候使用?
- 思考题:整数数组中唯一一个出现1次的数字?
- 手撕:下一个更大的数?