源码教程 2025年06月7日
0 收藏 0 点赞 437 浏览 1900 个字
摘要 :

1.在析构函数中使用new来分配内存时,必须在相应的析构函数中使用delete来释放内存。使用new的类通常需要包含显示复制函数和执行深度复制的赋值运算符。(见下2) 2.Str……

1.在析构函数中使用new来分配内存时,必须在相应的析构函数中使用delete来释放内存。使用new的类通常需要包含显示复制函数和执行深度复制的赋值运算符。(见下2)

2.StringBad sports("Spainshu leavea"); //StringBad 是一个类 调用的构造函数形式为:

StringBad ( const char *s);

StringBad sailor=sports; //用一个对象初始化另一个对象,调用的构造函数形式为:

 (1)StringBad ( const StringBad & st) {   //复制构造函数

 num_strings++;

len=st.len; str=new char[len+1];  std::strcpy(str,st.str);   }

(2)还需要编写执行深度复制的类重载赋值运算符:

  StringBad & StringBad::operator=(const StringBAd & st)  {

  if (this==&st) return *this;

 delete [] str; //释放旧的字符串

len=st.len;  str= new char [len+1];  std::strcpy(str,st.str);

return *this;  }

按值传递和返回对象,都调用复制构造函数。按引用传递时,将减少调用构造函数的时间。

3.静态数据,在类声明中声明,在类方法的文件中初始化。静态成员static,不管创建多少个对象,但只创建一个静态成员副本。

将成员函数声明为静态的,则不能通过对象调用静态成员函数,也不能使用this指针。静态成员函数声明放在公有声明部分,可以使用类名和作用解析运算符来调用它

4.如果类中包含了使用new初始化的指针成员,应当自行定义一个复制构造函数,以复制指向的数据,而不是指针,这叫深度复制。浅复制只复制指针信息,不会深入挖掘以复制指针引用的结构。

5.如果有多个构造函数,则都必须以相同的方式使用new,无参数的构造函数有new时:

String::String()

{   len=0;  str=new char[1];  str[0]='�';   } 

析构函数: String::~String() { delete   [ ] str; }

6. String *first=&saying[0];  //将指针初始化为指向已有的对象 

  String * second=neew String(sayings[1]); //用new来初始化指针,创建一个新对象 删除:delete second; //将调用动态对象*second的析构函数。

7. char *buffer = new char [512];

   JustTesting *pc1,*pc2; //  JustTesting是一个类

 pc1=new (buffer) JustTesting;// 此句为定位new运算符   

delete pc1; //不合法 需显示调用析构函数才能销毁对象: pc2->~JustTesting();   

delete  [] buffer; //合法

pc2=new JustTesting ("Heap", 20); //常规new运算符  …… delete pc2; //合法 ,将自动调用析构函数

8.C++11中空指针:NULL、0、nullptr

9. 对于被声明为引用和const 的类成员,在创建时应当成员初始化列表方式:(这种方法只用于构造函数)

 (1)class Queue { private : …..  int items; .const int qsize;   };   

   Queue::Queue(int qs) : qsize (qs) {  item=0; front =rear=NULL;  }  //

或者  Queue::Queue(int qs) : qsize (qs) , item(0) ,front (NULL), rear(NULL){ }

(2) class Agency{…}

   class Agent { private:  Agency &belong;…..};

   Agent::Agent(Agency &a): belong(a)  {…….}   

10. C++11允许在类定义中初始化。

class Queue

{ private: …..int item=0; …  const int qsize=Q_SIZE;

};

但使用成员初始化列表的构造函数将覆盖相应的类内初始化。

————————————————

原文链接:https://blog.csdn.net/lvliang2017232003/java/article/details/86515420

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/338.html

管理员

上一篇: C++Primer
相关推荐
2025-07-05

对于一些使用WordPress进行外贸建站的商家来说,大部分人会通过在WordPress中添加JS代码和CSS样式表…

708
2025-07-05

当商家遇到WordPress独立站改版或者域名到期等问题时,不免会涉及到WordPress域名的更改,那么这一…

726
2025-07-05

用户在使用WooCommerce进行跨境电商独立站搭建工作时,有可能会借助WooCommerce短代码实现更加醒目…

315
2025-07-05

随着外贸建站行业的不断深入发展,WordPress的多语言功能也显得越来越重要,一个具有多语言的独立站…

1,050
2025-07-05

WooCommerce作为WordPress外贸建站生态的一部分,WooCommerce运费设置是商家在建站过程中不可忽视的…

843
2025-07-05

在外贸建站的过程中,有些商家会选择使用WordPress幻灯片为网站页面增加一定的动感和可观性,进而提…

729
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号