age = age; this-_c++实例化对象">
当前位置:   article > 正文

c++三种实例化对象方式_c++实例化对象

c++实例化对象

1.隐式创建

首先我们定义一个测试类

class Person {
    private:
      int age;
      string name;
    public:
        Person() {
            cout<<"this is construct~";
        }
        Person(int age, string name) {
            this->age = age;
            this->name = name;
            cout<<"name is: "<<name<<", age is: "<<age<<endl;
        }
};
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

然后我们在main方法中隐式创建Person对象

Person p1;
cout<<endl;
Person p2(18, "lili");
cout<<endl;
  • 1
  • 2
  • 3
  • 4

2.显示创建

当然,我们也可以像其他编程语言一样,显示创建一个对象

Person p3 = Person();
cout<<endl;
Person p4 = Person(16, "xx");
cout<<endl;
  • 1
  • 2
  • 3
  • 4

这种方式,与上面的第一种方式原理基本一直。

3.用new创建

当然我们还可以用new关键字来创建对象

Person *p5 = new Person();
cout<<endl;
Person *p6 = new Person(14, "yy");
  • 1
  • 2
  • 3

注意new出来的对象,都需要用指针接收。

4.上述三种方式的区别

上面三种方式可以认为是两种方式,因为第一种方式与第二种方式基本相同。那么具体区别在哪里?

1.new出来的对象必须要用指针接收,并且需要显式delete销毁对象释放内存。

2.内存位置不同。
对于隐式声明

Person p1;
  • 1

p1对象位于栈空间。

Person *p5 = new Person();
  • 1

p5对象位于堆空间。

3.内存分配时间不同
使用隐式创建对象的时候,创建支出就已经分配了内存。而使用new的方式,如果对象没有初始化,此时没有分配内存空间,也无法delete。

Person *p = NULL;
delete p;
  • 1
  • 2

上述语句如果执行,会有各种意想不到的情况发生。

4.隐式声明的对象是局部变量,出了函数就没有了。而new出来的指针对象可以在方法之间传递,且该指针对象所指向的堆中的对象实例仍然存在。

5.频繁调用场合并不适合new,就像new申请和释放内存一样。

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号