《剑指offer》面试题01:赋值运算符函数

标签: 剑指offer 赋值运算符函数
24人阅读 评论(0) 收藏 举报
分类:

更多剑指offer习题请点击:《剑指offer》(第二版)题集目录索引

题目:
  如下为类型CMyString的声明,请为该类型添加赋值运算符函数。

class CMyString
{
public:
    CMyString(char* pData = nullptr);
    CMyString(const CMyString& str);
    ~CMyString(void);

    CMyString& operator = (const CMyString& str);

    void Print();

private:
    char* m_pData;
};

1. 传统写法

CMyString& CMyString::operator = (const CMyString& str) //传统写法
{
    // 1.检查自赋值
    if (this != &str)
    {
        // 2.分配新的内存资源,并复制内容
        char* tmp = new char[strlen(str.m_pData) + 1];
        strcpy(tmp, str.m_pData);

        // 3.释放原有的内存资源
        delete[]m_pData;
        m_pData = tmp;
    }
    // 4.返回本对象的使用
    return *this;
}
  1. 检查自赋值。防止出现 a = a或者p = &a; a = *p这种代码。注意不要写成if (*this != str)

  2. 分配新的内存资源,并复制字符串。如果是先释放了原有的内存资源,那么若后来的内存分配失败,那就惨了!所以先分配内存给一个临时变量,万一分配失败(抛出异常)也不会改变this对象,这是为了实现异常安全。

  3. delete[]释放原有内存资源。现在不释放,后面就没机会释放了,会造成内存泄漏。

  4. 返回本对象的引用,是为了实现如a = b = c; 这样的链式表达式。注意不能返回str,因为它可能是个临时对象,在赋值结束后马上消失,那么return other; 返回的将是垃圾。

2.现代写法

void CMyString::Swap(CMyString& other)
{
    swap(m_pData, other.m_pData);
}

CMyString& CMyString::operator = (CMyString str) //现代写法
{
    str.Swap(*this); //直接与临时对象进行交换,异常安全的。
    return *this;
}

< Test Code>

void Test1()
{
    printf("Test1 begins:\n");

    char* text = "Hello world";

    CMyString str1(text);
    CMyString str2;
    str2 = str1;

    printf("The expected result is: %s.\n", text);

    printf("The actual result is: ");
    str2.Print();
    printf("\n\n");
}

// 赋值给自己
void Test2()
{
    printf("Test2 begins:\n");

    char* text = "Hello world";

    CMyString str1(text);
    str1 = str1;

    printf("The expected result is: %s.\n", text);

    printf("The actual result is: ");
    str1.Print();
    printf("\n\n");
}

// 连续赋值
void Test3()
{
    printf("Test3 begins:\n");

    char* text = "Hello world";

    CMyString str1(text);
    CMyString str2, str3;
    str3 = str2 = str1;

    printf("The expected result is: %s.\n", text);

    printf("The actual result is: ");
    str2.Print();
    printf("\n\n");

    printf("The expected result is: %s.\n", text);

    printf("The actual result is: ");
    str3.Print();
    printf("\n\n");
}

int main(int argc, char* argv[])
{
    Test1();
    Test2();
    Test3();

    system("pause");
    return 0;
}

运行结果:
这里写图片描述

查看评论

RxJava精品课程01

本课程为系列课程。从RxJava1.0入门讲解到2.0版本的提升。针对每个API 的讲解分解API调用难度.本套课程为系列一,主要讲解如何学习RxJava.
  • 2017年04月05日 16:19

剑指offer面试题(一):赋值运算符函数

对于定义一个赋值运算符函数时,需要注意一下几点: (1)函数的返回类型必须是一个引用,因为只有返回引用,才可以连续赋值 (2)传入的参数声明为常量引用,可以提高代码效率,同时赋值运算函数内不会改变...
  • kerry0071
  • kerry0071
  • 2014-09-15 11:41:04
  • 3475

C/C++面试题(3)——剑指offer1(赋值运算符函数)

今天又复习了C++面试题,这道题的目的是:给出一个类的声明,然后写出这个类的构造函数、析构函数、拷贝构造函数和运算符重载函数。 题目 //题目:如下为类型CMyString的声明,请为该类型添加赋值...
  • jobbofhe
  • jobbofhe
  • 2016-09-01 00:00:06
  • 867

剑指offer——面试题1:赋值运算符函数

题目:如下为类型CMyString的声明,请为该类型添加赋值运算符函数。 class CMyString { public: CMyString(char* pData = NULL); CMyStr...
  • sinat_20265495
  • sinat_20265495
  • 2016-06-10 16:04:20
  • 443

剑指offer-面试题1:赋值运算符函数

题目:如下为类型CMyString的声明,请为该类型添加赋值运算符函数 class CMyString { public: CMyString(char *pData=NULL); C...
  • u013018721
  • u013018721
  • 2016-04-07 18:52:08
  • 477

剑指offer 面试题1

题目:赋值运算符函数写出一个类的赋值运算符。 注意事项: 1.是否返回该类的引用类型2.是否传入的参数类型是常量引用。3.是否释放自身已有内存4.是否是同一实例代码如下:CMyString & C...
  • u011058765
  • u011058765
  • 2015-06-19 16:17:14
  • 553

剑指offer1:赋值运算符函数

#include using namespace std; class CMyString{ public: CMyString(char* pData=NULL) { ...
  • u013207865
  • u013207865
  • 2016-04-04 11:40:21
  • 182

剑指Offer:面试题01---赋值运算符函数

题目: 如下为类型CMyString的声明,请为该类型添加赋值运算符函数。 class CMyString { public: CMyString(char *pData=NULL); ...
  • dl0914791011
  • dl0914791011
  • 2013-11-25 16:26:02
  • 1178

剑指offer面试题 java解答1-5

面试题1:赋值运算符函数 Java中不能重载运算符(C++可以) String 类的“+”是通过StringBuidler的append追加实现的。 可以重写自定...
  • frasker
  • frasker
  • 2016-08-22 16:19:38
  • 605

[剑指offer]之python实现总结[持续更新中]

一 递归 使用记录减少递归层数提升效率 斐波那契数列 跳台阶 变态跳台阶 矩形覆盖 链表的遍历 反转链表 涉及树的遍历 二叉树的深度 平衡二叉树 树的子结构 二叉树的镜像 二 交换[类似快排]...
  • huaxixidongbeishida
  • huaxixidongbeishida
  • 2016-10-22 16:43:42
  • 1200
    个人资料
    持之以恒
    等级:
    访问量: 2万+
    积分: 1542
    排名: 3万+
    最新评论