赋值运算符函数__from <剑指Offer>

        前段时间忙于项目,难得偷得几日闲,为即将到来的就业季做准备。在面试时,应聘者要注意多和考官交流,只有具备良好的沟通能力,才能充分了解面试官的需求,从而有针对性地选择算法解决问题。

        题目来源于《剑指Offer》,自己在原有基础上稍作批注和修改。

        问题:为类型添加赋值运算符函数,可以把CMyString实例赋值给另一个实例、自身和连续赋值。

        学习点:考虑问题充分,自己不会把赋值情况、内存泄漏考虑到这么细致。

#include<cstring>
#include<cstdio>

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

private:
    char* m_pData;  //类比C风格字符串
};

CMyString::CMyString(char * pData)
{
    if (pData==nullptr)  //空指针
    {
        //创建空字符串
        m_pData = new char[1];
        m_pData[0] = '\0';
    }
    else
    {
        int length = strlen(pData);
        m_pData = new char[length + 1];
        //复制
        /*
            char * strcpy(char * destination, const char * source);
            Copies the C string pointed by source into the array pointed by destination, including the terminating null character(and stopping at that point).
        */
        strcpy(m_pData, pData);
    }
}

CMyString::CMyString(const CMyString& str)
{
    int length = strlen(str.m_pData);  //Returns the length of the C string str. The length of a C string is determined by the terminating null - character
    m_pData = new char[length + 1];  //new分配内存后,默认使用delete释放对象
    strcpy(m_pData, str.m_pData);
}

CMyString::~CMyString(void)
{
    delete[] m_pData;
}

//1. 返回值的类型声明为该类型的引用,程序结束前返回实例自身的引用(*this)
//2. 传入的参数的类型声明为常量引用
//3. 释放实例自身的内存
//4. 判断传入的参数和当前的实例是不是同一个实例
//5. 升级:考虑异常安全性的解法 先new再delete
CMyString& CMyString::operator=(const CMyString& str)  //参考2
{
    if (this != &str)  //参考4
    {
        CMyString strTemp(str);  //临时实例
        //参考3
        char* pTemp = strTemp.m_pData;
        strTemp.m_pData= m_pData;
        m_pData = pTemp;
    }//调用strTemp的析构函数,释放其内存
    //参考1
    return *this;
}

//=================  测试代码  ==================
void CMyString::Print()
{
    printf("%s", m_pData);
}

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");
}

// 赋值给自己
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");
}

// 连续赋值
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");

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

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

int main(int argc, char* argv[])
{
    Test1();
    Test2();
    Test3();
    getchar();  //等待输入
    return 0;
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏来自地球男人的部落格

正则表达式匹配

【原题】 请实现一个函数用来匹配包括’.’和’*’的正则表达式。模式中的字符’.’表示任意一个字符,而’*’表示它前面的字符可以出现任意次(包含0次)。 在...

2005
来自专栏计算机视觉与深度学习基础

Leetcode 54 Spiral Matrix

Given a matrix of m x n elements (m rows, n columns), return all elements of th...

1797
来自专栏林德熙的博客

win10 uwp 初始屏幕

对于本地 127.0.0.1 就是一个内部IP,之外,还有10.0.0.0/24 ,172.16.0.0/16 , 192.168.0.0/16 , 169.2...

62
来自专栏猿人谷

编程小技巧

1.判断一个自然数是否是某个数的平方?(其实就是判断这个数一定是奇数相加的) 由于 (n+1)^2 =n^2 + 2n + 1, = ... = 1 +...

18910
来自专栏互联网杂技

CSS3矩阵变换

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <style>...

33810
来自专栏猿人谷

字符串的排列

题目:输入一个字符串,打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出字符a、b、c所能排列出来的所有字符串abc、acb、bac、bca、ca...

1636
来自专栏测试开发架构之路

程序员面试50题(3)—翻转句子中单词的顺序[算法]

题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。 例如输入“I am a ...

2716
来自专栏乐沙弥的世界

MongoDB 数组元素增删改

544
来自专栏林德熙的博客

win10 uwp 判断本地ip

对于本地 127.0.0.1 就是一个内部IP,之外,还有10.0.0.0/24 ,172.16.0.0/16 , 192.168.0.0/16 , 169.2...

131
来自专栏深度学习与计算机视觉

算法-调整数组顺组使奇数位于偶数前面

题目: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,偶数位于数组的后半部分。 解题思路: 比如我们有一个这样...

1807

扫描关注云+社区