如何在默认构造函数中将char数组初始化为null?

时间:2017-03-23 02:05:31

标签: c++ arrays memory dynamic char

我试图在默认构造函数中设置一个等于null('\ 0')的char数组。我试图在没有传递参数时将已初始化的char指针(该类的受保护成员)的值设置为null。如果传递了正确的参数,程序将完美运行,但是当我在默认构造函数中设置它们时,我得到一个分段错误:11错误。

这是头文件:

#ifndef _DVD_H_
#define _DVD_H_

class DVD {
protected:
    unsigned int id;
    char* title;
    char* director;
    char* makecopy(const char*);
public:
    DVD(unsigned int i, const char* t, const char* dir);
    void display();
    DVD () 
    {
        const char temp[] = {'\0'};
        id = 0;
        title = makecopy(temp);
        director = makecopy(temp);

    }
};

#endif /* _DVD_H_ */ 

这是.cpp文件:

#include <iostream>
#include "DVD.h"
using namespace std;

DVD::DVD (unsigned int i, const char* t, const char* dir)
{
    //Constructing id
    id = i;
    //Constructing title
    title = makecopy(t);
    //Constructing director
    director = makecopy(dir);
}

void DVD::display()
{
    //Creating variables to track the length of the title/director and the location of the space. 
    int len_t,len_dir,space_dir;
    for (len_t = 0; title[len_t] != '\0'; len_t++)
        ;
    for (len_dir = 0; director[len_dir] != '\0'; len_dir++)
        ;
    for (space_dir = 0; director[space_dir] != ' '; space_dir++)
        ;
    //Display the information in the desired format. 
    cout << '[' << id << ". " << title << '/';
    for (int p = 0; p < space_dir; p++)
     cout << director[p];
    for (int j = space_dir; j < len_dir; j++)
        cout << director[j];
    cout << ']' << endl;
}

char* DVD::makecopy(const char* str)
{
    int len;
    char* copy;
    for (len = 0; str[len] != '\0'; len++)
        ;
    copy = new char[len+1];
    for (int i = 0; i < len+1; i++)
        copy[i] = str[i];
    return copy;
}

这是另一个.cpp文件

#include<iostream>
using namespace std;
#include"DVD.h"

int main()
{
    char str[] = "Gandhi";
    DVD d1(4, str, "Richard Attenborough");
    DVD d2;
    cout << "First step: " << endl;

    cout << "After constructors:" << endl;
    d1.display(); cout << endl; // [4.  Gandhi/Richard Attenborough]
    d2.display(); cout << endl; // [0.  /]


     cout << "Test for dynamically allocated copies" << endl;
     d1.display(); cout << endl; // [4.  Gandhi/Richard Attenborough]
     d2.display(); cout << endl; // [0.  /]
}

1 个答案:

答案 0 :(得分:1)

您没有实施Rule of Three,而您的makecopy()是可疑的。

尝试更像这样的东西:

#ifndef _DVD_H_
#define _DVD_H_

class DVD
{
protected:
    unsigned int id;
    char* title;
    char* director;

    static char* makecopy(const char* str);

public:
    DVD();
    DVD(unsigned int i, const char* t, const char* dir);
    DVD(const DVD &src);
    ~DVD();

    DVD& operator=(const DVD &rhs);

    void display() const;
};

#include "DVD.h"
#include <iostream>

DVD::DVD() 
    : id(0), title(NULL), director(NULL)
{
}

DVD::DVD(unsigned int i, const char* t, const char* dir)
    id(i), title(makecopy(t)), director(makecopy(dir))
{
}

DVD::DVD(const DVD& src)
    id(src.id), title(makecopy(src.title)), director(makecopy(src.director))
{
}

DVD::~DVD()
{
    delete[] title;
    delete[] director;
}

DVD& DVD::operator=(const DVD& rhs)
{
    if (this != &rhs)
    {
        DVD copy(rhs);

        id = copy.id;

        char *c_temp = copy.title;
        copy.title = title;
        title = c_temp;

        c_temp = copy.director;
        copy.director = director;
        director = c_temp;
    }

    return *this;
}

void DVD::display() const
{
    //Display the information in the desired format. 
    std::cout << '[' << id << ". " << title << '/' << director << ']' << std::endl;
}

char* DVD::makecopy(const char* str)
{
    int len = 0;
    if (str)
    {
        while (str[len] != '\0')
            ++len;
    }

    char* copy = new char[len+1];
    for (int i = 0; i < len; ++i)
        copy[i] = str[i];
    copy[len] = '\0';

    return copy;
}

话虽如此,我强烈建议您改用std::string。让它和编译器为您处理所有内存管理:

#ifndef _DVD_H_
#define _DVD_H_

#include <string>

class DVD
{
protected:
    unsigned int id;
    std::string title;
    std::string director;

public:
    DVD();
    DVD(unsigned int i, const std::string& t, const std::string& dir);

    void display() const;
};

#endif /* _DVD_H_ */ 

#include "DVD.h"
#include <iostream>

DVD::DVD()
    : id(0)
{
}

DVD::DVD(unsigned int i, const std::string& t, const std::string& dir)
    : id(i), title(t), director(dir)
{
}

void DVD::display() const
{
    //Display the information in the desired format. 
    std::cout << '[' << id << ". " << title << '/' << director << ']' << std::endl;
}