C++ part3
函数和const
references:
C++中const用于函数重载
有些情况可以重载,有些不行,具体看↑。
隐式类型转换
references:
nowcoder
对于内置类型,低精度的变量给高精度变量赋值会发生隐式类型转换。
对于只存在单个参数的构造函数的对象构造来说(并不是指构造函数只能有一个形参,而是它可以有多个形参,但那些形参都是有默认实参的),函数调用可以直接使用该参数传入,编译器会自动调用其构造函数生成临时对象。
class A{
A(int f, int d = 0){}
};
...
A a = 10;
用explicit可以防止隐式类型转换
C++函数栈空间的最大值
和os有关,自己查。
extern“C”
references:
extern "c"用法解析
extern"C"的使用
加上extern "C"后,会指示编译器这部分代码按C语言的进行编译,而不是C++的。
比如说你用C 开发了一个DLL 库,为了能够让C ++语言也能够调用你的DLL输出(Export)的函数,你需要用extern "C"来强制编译器不要修改你的函数名。
extern "C"{
extern void f();
}
int main(){
f();
return 0;
}
new/delete与malloc/free的区别
RTTI(运行阶段类型识别)
references:
C++ 中的RTTI机制详解
C++ primer
Runtime Type Information缩写。
1、typeid函数和type_info类
使用typeid函数来获得对象的类型。typeid会返回一个type_info类的对象,调用这个对象的name()函数可知道具体类型(包括自定义类)。type_info类中重载了==和!=比较两个对象的类型是否相等。当类中不存在虚函数时,typeid是编译时期的事情,也就是静态类型;当类中存在虚函数时,typeid是运行时期的事情,也就是动态类型。 也就是说当类中有虚函数时,基类指针指向的派生类对象会被认为是派生类。
2、dynamic_cast
需要虚函数,失败返回NULL
C语言参数压栈顺序
从右到左
C语言是怎么进行函数调用的
references:
C/C++ 函数调用栈过程
C&C++函数调用过程
一篇文章了解C语言函数调用栈——程序员进阶必备
1、参数入栈
2、返回地址入栈
3、函数栈帧开辟
4、函数栈帧回退
C++如何处理返回值
references:
nowcoder
生成一个临时变量,把它的引用作为函数参数传入函数内。
C++中拷贝赋值函数的形参能否进行值传递?
不能。如果是这种情况下,调用拷贝构造函数的时候,首先要将实参传递给形参,这个传递的时候又要调用拷贝构造函数。。如此循环,无法完成拷贝,栈也会满。
select(不会)
fork,wait,exec函数
references:
进程控制——fork-and-exec、system、wait
fork从父进程返回子进程的pid,从子进程返回0。
调用了wait的父进程将会发生阻塞,直到有子进程状态改变,执行成功返回0,错误返回-1。
exec函数执行成功则子进程从新的程序开始运行,无返回值,执行失败返回-1。
exec的函数有很多个,它们分别是execve、execl、execv、execle、execlp、execvp,都是加载函数。其中execve是系统函数。