类的构造和析构
2017-04-20 13:21
120 查看
所有的事物在起初的时候,都应该有一个初始状态,而当这个事物完成其使命后,也应该清楚外界作用于这个事物上的信息。为了给我们提供这种问题的解决方案,构造函数和析构函数,会被编译器自动调用,完成对象的初始化和清理。
构造函数的语法:
构造函数函数名和类名相同,无返回值,但可以由参数。classname(){}
按参数分为:无参构造函数和有参构造函数
按类型分为:普通构造函数和拷贝构造函数 person(cosnt class& class)
无参构造调用 class class;
有参构造调用 class class(parameter...)
析构函数函数名是在类名前面加“~”组成,没有返回值,不能有参数,不能重载。
class person
{
private:
char *name;
public:
person()//无参构造
{
this->name = (char*)malloc(30);
memset(this->name, 0, 30);
strcpy(this->name, "no parameter");
//std::cout << "malloc for name" << std::endl;
std::cout << "无参构造"<< std::endl;
}
person(const char* p)//有参构造
{
this->name = (char*)malloc(30);
memset(this->name, 0, 30);
strcpy(this->name, p);
//std::cout << p<< std::endl;
std::cout << "有参构造" << std::endl;
}
person(const person& per)//拷贝构造
{
this->name = (char*)malloc(30);
memset(this->name, 0, 30);
strcpy(this->name, per.name);
std::cout << "拷贝构造" << std::endl;
}
~person()
{
if (this->name != NULL)
{
free(name);
name = NULL;
}
std::cout << "析构" << std::endl;
}
};
void test()
{
person per0;//无参构造
person per1 = person("aabbccdd");//有参构造
person per2 = person(per0);//拷贝构造
person per3 = per1;//调用拷贝构造
person per4 = "ddccbbaa";//隐式转换,相当于per3=person("ddccbbaa");
}
int main()
{
test();
system("pause");
return 0;
}
构造函数的语法:
构造函数函数名和类名相同,无返回值,但可以由参数。classname(){}
按参数分为:无参构造函数和有参构造函数
按类型分为:普通构造函数和拷贝构造函数 person(cosnt class& class)
无参构造调用 class class;
有参构造调用 class class(parameter...)
析构函数函数名是在类名前面加“~”组成,没有返回值,不能有参数,不能重载。
class person
{
private:
char *name;
public:
person()//无参构造
{
this->name = (char*)malloc(30);
memset(this->name, 0, 30);
strcpy(this->name, "no parameter");
//std::cout << "malloc for name" << std::endl;
std::cout << "无参构造"<< std::endl;
}
person(const char* p)//有参构造
{
this->name = (char*)malloc(30);
memset(this->name, 0, 30);
strcpy(this->name, p);
//std::cout << p<< std::endl;
std::cout << "有参构造" << std::endl;
}
person(const person& per)//拷贝构造
{
this->name = (char*)malloc(30);
memset(this->name, 0, 30);
strcpy(this->name, per.name);
std::cout << "拷贝构造" << std::endl;
}
~person()
{
if (this->name != NULL)
{
free(name);
name = NULL;
}
std::cout << "析构" << std::endl;
}
};
void test()
{
person per0;//无参构造
person per1 = person("aabbccdd");//有参构造
person per2 = person(per0);//拷贝构造
person per3 = per1;//调用拷贝构造
person per4 = "ddccbbaa";//隐式转换,相当于per3=person("ddccbbaa");
}
int main()
{
test();
system("pause");
return 0;
}
相关文章推荐
- 构造与析构的次序
- Item 9:绝不在构造和析构过程中调用虚函数【effective C++读书笔记】
- 深度探索C++对象模型:5.构造、析构、拷贝语意学
- 05_c++构造和析构
- PHP-----类与对象,成员方法,成员属性,构造方法,析构方法
- Java构造方法和析构方法
- 构造、析构、继承对对象的影响
- 条款09:绝不在构造和析构过程中调用virtual函数
- 再说构造与析构,virtual析构函数
- C++对象的构造、赋值和析构
- 临时对象的构造与析构
- 构造方法与析构方法区别
- 子类构造、析构时调用父类的构造、析构函数顺序
- [读书笔记] 深入探索C++对象模型-第五章-构造、析构、拷贝语义学(上)
- Effective C++ Item 9 绝不在构造和析构过程中调用virtual函数
- PHP面向对象_构造方法和析构方法
- C++ 类的相关知识 构造,析构,继承与多态
- 第五章 构造、析构、拷贝语意学
- 继承----构造与析构
- PHP5中面向对象的构造方法和析构方法