C++Primer读书笔记2
友元
友元可以是普通的非成员函数,或前面定义的其他类的成员函数,或整个类,将一个类声明为友元,友元类的所有成员函数可以访问授予友元关系类的所有成员。
2. 必须先定义包含成员函数的类,才能将成员函数设为友元
如果基类定义了static成员,则整个继承层次中只有一个这样的成员,无论从基类派生出多少个派生类,每个static成员只有一个。
示例:
析构函数
用于释放在构造函数或在对象生命期内获取的资源。
如果类需要析构函数,那么也需要复制操作符和复制构造函数。
何时调用析构函数?
当对象的引用或指针超出作用域时,不会运行析构函数,只有删除指向动态分配对象的指针或实际对象(而不是对象的引用)超出作用域时,才会运行析构函数。
合成析构函数:
编译器总是为我们合成一个析构函数,合成析构函数按对象创建时的逆序撤销每个非static成员,对于类类型的成员,合成析构函数调用该成员的析构函数来撤销对象。
析构函数是在类名字前加~,没有返回值,没有形参,不能重载析构函数,我们可以为一个类定义多个构造函数,但只能提供一个析构函数
析构函数和构造函数的一个不同是,即使你定义了析构函数,合成析构函数也会运行。
赋值操作符
与复制构造函数一样,如果一个类没有定义自己的赋值操作符,编译器就会合成一个
合成的赋值操作符与合成的复制构造函数一样,进行逐个成员的赋值,
管理指针成员
1. 一个带指针成员的简单类
class HasPtr
{
public:
HasPtr(int*i,int j):ptr(i),val(j)
{};
int*get_ptr() const
{
returnptr;
}
int get_int() const
{
return val;
}
voidset_ptr(int *p)
{
ptr=p;
}
voidset_int(int i)
{
val=i;
}
intget_ptr_val()
{
return *ptr;
}
voidset_ptr_val(int val) const
{
*ptr=val;
val++;
}
int *ptr;
int val;
};
int main()
{
int *i=newint(1);
HasPtrhasPtr1(i,2);
HasPtrhasPtr2(hasPtr1); //调用默认的合成复制构造函数,是hasPtr1和hasPtr2的ptr指向同一处
//cout<<&(hasPtr1.val)<<endl;
//cout<<&(hasPtr2.val)<<endl;//addresses are different
//cout<<hasPtr1.ptr<<endl;
//cout<<hasPtr2.ptr<<endl;//addresses are same
delete i;
cout<<*(hasPtr1.ptr)<<endl;//野指针
cout<<hasPtr1.get_ptr()<<endl;
getchar();
return 0;
}
2. 定义智能指针
auto_ptr
C++的auto_ptr所做的事情,就是动态分配对象以及当对象不再需要时自动执行清理。
补充:软件开发 , C++ ,