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


构造函数:

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. Cannot update paths and switch to branch at the same time(转)

    当使用git进行操作: git checkout -b local-name origin/remote-name 出现错误: fatal: git checkout: updating paths ...

  2. projecteuler----&gt;problem=34----Digit factorials

    Problem 34 145 is a curious number, as 1! + 4! + 5! = 1 + 24 + 120 = 145. Find the sum of all number ...

  3. NYNU_省赛选拔题(6)

    题目描述 有一天,小米找到了一个藏宝的迷宫地图,迷宫在一个沙漠里有,迷宫里面有许多宝藏.迷宫里可能有N个藏宝地点,用1到K标记.藏宝地点之间最多有一条通路相连.标记1为迷宫的进出口. 他已经知道其中K ...

  4. [Error]EOL while scanning string literal

    有一个经常性的工作项目.需要一天的一些表数据到外部接口,但最近总是异常.今天检查的原因. 第一本地和测试环境中测试程序是没有问题,有网络环境只会在日志中抛出一个异常.产生主要的例外是推定异常数据. , ...

  5. mac_开启ftp并访问

    [启动&关闭] mac下一般用smb服务来进行远程文件访问,但要用FTP的话,高版本的mac os默认关掉了,可以用如下命令打开: sudo -s launchctl load -w /Sys ...

  6. 【SSH三个框架】Hibernate第十篇基础:inverse属性具体解释

    inverse后经常用于双向1-N在相关性.它也可以在使用N-N该协会,这里,例如用双1-N联想 或两个与各部门及工作人员,两javabean没有写. 首先,我们的员工看映射文件: <?xml ...

  7. linux_shell_轮询触发启动脚本

    while [ 1 ]do length=`redis-cli -h *.*.*.* -p 8000 llen eq` while [ $length -gt 1 ] do echo "le ...

  8. AJAX及其跨域的主要解决方法

    AJAX = Asynchronous JavaScript andXML(异步的 JavaScript 和 XML).通过在后台与服务器进行少量数据交换,使网页实现异步更新.要明白异步交互可以通过同 ...

  9. 使用Navicat Premium 和PL\SQL Developer连接Oracl

    在64位Win7中使用Navicat Premium 和PL\SQL Developer连接Oracle数据库备忘   最近接手了一个项目,服务器端数据库是oracle 11g 64位.由于主要工作不 ...

  10. jquery 调用wcf 的SOA架构,将三层架构运用到SOA的架构中来(第四天)

    经过前面3天的学习,我想大家应该对SOA的架构有了初步的了解,其实 SOA与三层架构并不冲突,而是三层架构的升级版. 来看下传统的三层架构! 一共可以分为4个层: 模型层(可有可无),客户端,服务端, ...