博客
关于我
20170825_string构造函数、析构函数、拷贝构造函数以及重载赋值运算符
阅读量:96 次
发布时间:2019-02-25

本文共 689 字,大约阅读时间需要 2 分钟。

20170825_string构造函数、析构函数、拷贝构造函数以及重载赋值运算符

//string类的构造函数#include
#include
#include
using namespace std;//编写类String的构造函数、析构函数和赋值函数,已知类String的原型为: class String{public: String(const char *str = NULL); // 普通构造函数 String(const String &other); // 拷贝构造函数 ~String(void); // 析构函数 String & operator=(const String &other); // 赋值函数 private: char *m_data; // 用于保存字符串 };//1、普通构造函数String::String(const char *str) { if(str==NULL) { m_data = new char[1]; //得分点:对空字符串自动申请存放结束标志'\0'的空间 *m_data = '\0'; //加分点:对m_data加 NULL 判断 } else { int length = strlen(str); m_data = new char[length+1]; //若能加 NULL 判断则更好 if(m_data==nullptr) { cout<<"out of space!"<

转载地址:http://lzz.baihongyu.com/

你可能感兴趣的文章
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
mysql 状态检查,备份,修复
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>
MySQL 的mysql_secure_installation安全脚本执行过程介绍
查看>>
MySQL 的Rename Table语句
查看>>
MySQL 的全局锁、表锁和行锁
查看>>
mysql 的存储引擎介绍
查看>>
MySQL 的存储引擎有哪些?为什么常用InnoDB?
查看>>