为什么用构造函数与析构函数


构造函数:

c++目标是让使用类对象就像使用标准类型一样,但是常规化的初始化句法不适用与类类型。

 int year =; //基本类型
struct thing {
char *pn;
int m;
};
thing amabob = {"jiang",-}; //结构体的初始化,结构体默认的访问类型是public,可以直接访问

类对象的数据部分的访问状态都是私有的,程序不能直接访问数据成员。

程序只能通过成员函数才能访问数据成员,因此要设计合适的成员函数,才能成功的将对象初始化。

析构函数:

用构造函数创建对象后,程序负责跟踪该对象,直到过期为止,对象过期时,程序将自动调用一个特殊的成员函数,析构函数。如果构造函数用new来分配内存,则析构函数用delete来释放这些内存。

如果大家还想了解的更多,可以参考陈树振老师的博文:http://blog.csdn.net/chenshuzhenteacher/article/details/8094577


怎么用构造函数与析构函数


构造函数

c++提供了两种方法初始化对象的方式,第一种是显式的调用构造函数:

Stock food = Stock ("World Cabbage",250,1.25);

另外一种是隐式调用构造函数

Stock garment("Furry Marson",50,2.5);

每次创建类对象(甚至使用new动态分配内存)时,C++都会使用类的构造函数。

Stock *pstock = new Stock("Elect",18,19);

无法使用对象调用构造函数,因为构造函数构造对象之前,对象是不存在的,因此构造函数用来创建对象,而不能通过对象来调用。

  1. 默认构造函数
  2. 无参构造函数
  3. 有参构造函数
  4. 拷贝构造函数
  5. 赋值构造函数

1.默认构造函数是在未提供显式的初始化值是被用来创建对象的构造函数,用于以下声明:

Stock stock;

创建stock对象,但不初始化成员,这和下面的语句

int x;

创建x,但没有提供值给他一样。默认构造函数没有参数,因此声明中不包含值。

如果提供非默认构造函数(如Stock(const char* co,int n,double pr)),但没有提供默认构造函数,则下面的声明是错误的:

Stock stock;

如果想要创建对象,而不显式的初始化,必须定义不接受任何参数的默认构造函数,有两种方法。

一种是给已有构造函数的所有参数提供默认值。Stock(const char *no = "ERROR",int n = 0 ,double pr = 0.0);

另一种方式是通过函数重载来定义另一个构造函数 Stock();

Stock first("dajdke"); //call constructor

Stock second(); //declares a function

Stock third;  //calls default constuctor

第一个声明调用非默认构造函数,即接收参数的构造函数,第二个声明指出,second()是一个返回Stock对象的函数,隐式的调用函数默认构造函数,不要使用圆括号。

2、无参构造函数

Type();
就是构造函数中没带参数。

3、有参构造函数

Type(int a );
就是构造函数中含有参数。

4、拷贝,赋值构造函数

class String {

private:
char * m_data; public:
String(const char *str = NULL); //普通构造函数
String(const String &other); //拷贝构造函数
String &operator = (const String &other); //赋值函数
~String(void); //析构函数 }; String::String(const char *str)
{
cout<<"自定义构造函数"<<endl;
if (str ==NULL) {
m_data = new char[];
*m_data = '\0';
} int length = sizeof(str);
m_data = new char[length+];
strcpy(m_data, str); }
String::String(const String &other)
{
cout<<"自定义拷贝构造函数"<<endl;
int length = sizeof(other.m_data);
m_data = new char [length + ];
strcpy(m_data, other.m_data); }
String &String:: operator=(const String &other)
{
cout<<"自定义赋值"<<endl;
if (this == &other) {
return *this;
}
else
{
delete [] m_data;
int length = sizeof(other.m_data);
m_data = new char [length + ];
strcpy(m_data, other.m_data);
return *this;
}
} String::~String()
{
cout<<"调用的析构函数"<<endl;
delete [] m_data;
} int main(int argc, const char * argv[])
{
cout<<"a(\"abc\")"<<endl;
String a("abc");//自定义构造函数
String b("cde");//自定义构造函数
String d = a;//自定义拷贝构造函数
String c(b);//自定义拷贝构造函数
c=a;// 自定义赋值
}

参考:http://blog.csdn.net/twlkyao/article/details/9104537

c++类的构造函数与析构函数的更多相关文章

  1. 不可或缺 Windows Native (21) - C++: 继承, 组合, 派生类的构造函数和析构函数, 基类与派生类的转换, 子对象的实例化, 基类成员的隐藏(派生类成员覆盖基类成员)

    [源码下载] 不可或缺 Windows Native (21) - C++: 继承, 组合, 派生类的构造函数和析构函数, 基类与派生类的转换, 子对象的实例化, 基类成员的隐藏(派生类成员覆盖基类成 ...

  2. C++:派生类的构造函数和析构函数

    4.2 派生类的构造函数和析构函数4.2.1 派生类构造函数和析构函数的执行顺序 通常情况下,当创建派生类对象时,首先执行基类的构造函数,随后再执行派生类的构造函数:当撤销派生类对象时,则先执行派生类 ...

  3. C++学习之路—继承与派生(二):派生类的构造函数与析构函数

    (根据<C++程序设计>(谭浩强)整理,整理者:华科小涛,@http://www.cnblogs.com/hust-ghtao转载请注明) 由于基类的构造函数和析构函数是不能被继承的,所以 ...

  4. C++:派生类的构造函数和析构函数的调用顺序

    一.派生类 在C++编程中,我们在编写一个基类的派生类时,大致可以分为四步: • 吸收基类的成员:不论是数据成员还是函数成员,派生类吸收除基类的构造函数和析构函数之外的全部成员. • 改造基类函数:在 ...

  5. C++学习笔记(6)----基类和派生类的构造函数和析构函数的执行顺序

    基类和派生类:构造函数和析构函数的执行顺序 在Visual Studio中,新建控制台工程,构造类如下: #include<iostream> using namespace std; c ...

  6. cc28c_demo.cpp,派生类的构造函数和析构函数-代码示范3

    cc28c_demo.cpp,派生类的构造函数和析构函数-代码示范3 //派生类的构造函数和析构函数//派生类的构造函数(执行步骤)//--执行基类的构造函数//--执行成员对象的构造函数//--执行 ...

  7. C++将类的构造函数、析构函数声明为private或者protected的用途

    如果将构造函数.析构函数声明为private或者protected,表示不能从类的外部正常调用构造和析构函数了. 这种用法的通常使用的场景如下: 1.如果不想让外面的用户直接构造一个类A的对象,而希望 ...

  8. c++, 派生类的构造函数和析构函数 , [ 以及operator=不能被继承 or Not的探讨]

    说明:文章中关于operator=实现的示例,从语法上是对的,但逻辑和习惯上都是错误的. 参见另一篇专门探究operator=的文章:<c++,operator=>http://www.c ...

  9. 拷贝构造函数,深拷贝,大约delete和default相关业务,explicit,给定初始类,构造函数和析构函数,成员函数和内联函数,关于记忆储存,默认参数,静态功能和正常功能,const功能,朋友

     1.拷贝构造 //拷贝构造的规则,有两种方式实现初始化. //1.一个是通过在后面:a(x),b(y)的方式实现初始化. //2.另外一种初始化的方式是直接在构造方法里面实现初始化. 案比例如以 ...

随机推荐

  1. A + B Again 2057 有符号的64进位的运算

    Problem Description There must be many A + B problems in our HDOJ , now a new one is coming.Give you ...

  2. JAVA设计模式(09):结构化-代理模式(Proxy)

    一,定义:  代理模式(Proxy):为其它对象提供一种代理以控制对这个对象的訪问. 二.其类图: 三,分类一:静态代理 1,介绍:也就是须要我们为目标对象编写一个代理对象,在编译期就生成了这个代理对 ...

  3. c++的string容器

    c++相比c的一个好处就是实现了很多的容器和泛型算法,使得程序员的工作得到了很大的化简.其中一个很有用的泛型容器就是string.string是一个类,是一个在STL里边实现好了的类,由于他的很多功能 ...

  4. oracle_深刻理解数据库的启动和关闭

    Oracle数据库提供了几种不同的数据库启动和关闭方式,本文将详细介绍这些启动和关闭方式之间的区别以及它们各自不同的功能. 一.启动和关闭Oracle数据库 对于大多数Oracle DBA来说,启动和 ...

  5. Mysql sql声明召回2 --正则表达式

    这里简单回顾mysql在过滤后的数据使用正则表达式时.主要利用每方法将样品,或添加一些简短的说明. 下面说说提前,使用正则表达式是用来过滤数据 REGEXPkeyword 基本字符相匹配: SELEC ...

  6. JS对文档进行操作

    对文档进行操作   创建节点 追加节点 删除节点 任务及例子 总结 对DOM的修改是,构建动态网页的关键.使用下面列举的方法,我们可以创建新的网页并且动态进行更改. 更多的DOM操作方法请查 DOM1 ...

  7. Hack 语言学习/参考---1.2 Hack Background

    Hack Background Facebook was initially built with PHP. Parameters and return types were specified in ...

  8. 分析Cocos2d-x横版ACT手游源 2、server场景

    仍然一样 直接在代码 资源 下一个 上传 你可以看到自己 NFServerChangeLayer.h </pre><pre name="code" class=& ...

  9. [Openstack] Expecting an auth URL via either --os-auth-url or env[OS_AUTH_URL]

    直接使用devstack在ubuntu14.04单个节点的建筑openstack 使用keystone查询租户和用户始终报告时,这个错误! 主要看下这些配置是否正确.我们将能够解决这个问题 opens ...

  10. hibernate的orphanRemoval

    在@OneToMany与@OneToOne中使用orphanRemoval = true时候 改动保存时候setXXX org.springframework.orm.hibernate3.Hiber ...