构造函数中的 C++ 初始化列表

Posted

技术标签:

【中文标题】构造函数中的 C++ 初始化列表【英文标题】:C++ initialization list in constructor 【发布时间】:2014-10-11 02:23:11 【问题描述】:

我正在尝试使用另一个名为“List”的类的构造函数中的初始化列表来初始化名为“Winery”的类的实例。问题是,当我将 Winery 构造函数交给一个要复制的酒厂时,它无法复制信息。

这是 Winery 类的头文件:

class Winery

public:

    Winery(const char * const name, const char * const location, const int acres, const int rating);
    virtual ~Winery(void);

    const char * const getName() const  return name; 
    const char * const getLocation() const  return location; 
    const int getAcres() const  return acres; 
    const int getRating() const  return rating; 

private:
    char    *name;
    char    *location;
    int     acres;
    int     rating;
;

这是我的 List 类的头文件的相关部分:

struct Node
    
        Node(const Winery& winery);     
        Winery item;                                            
        Node *nextByName;               
        Node *nextByRating;             
    ;

这是我的 List 类中的构造函数:

List::Node::Node(const Winery& winery) :
item(winery.getName(), winery.getLocation(), winery.getAcres(), winery.getRating()),
nextByName(nullptr),
nextByRating(nullptr)


在我看来,我似乎正在做我需要做的一切。我传递给构造函数的酒厂数据成员是私有的,所以我试图通过获取信息的函数来获取它们。他们的顺序和一切都是正确的。初始化它们后指针工作得很好,但信息不存在,所以我真的不知道该怎么做。如果您想知道,这是一个分配,我们必须使用初始化列表(我已经尝试过没有它们,但它也不起作用,所以我真的不知道该怎么做)。我将不胜感激任何帮助!谢谢!

编辑:这是我的酒厂构造函数:

Winery::Winery(const char * const name, const char * const location, const int acres, const int rating) :
acres(acres),
rating(rating)

    char *newName = new char[sizeof(name) + 1];
    char *newLocation = new char[sizeof(location) + 1];

【问题讨论】:

您必须定义“无法复制信息”的含义,因为这可能意味着任何事情。析构函数是什么样的?我的猜测是析构函数正在删除 newNamenewLocation 字符串。您是否有理由不使用 const char* 而不是 std::string 我的意思是当构造函数遍历完初始化列表后,我在内存中查看itemnextByNamenextByRatingnextByNamenextByRating 已初始化为 NULL,但 item 的所有四个部分仍然具有 Visual Studio 默认内存值(0xcdcdcdcd、0xfeeffeef 等)以及我使用 @987654336 的原因@ 是因为我们被禁止使用std::string 【参考方案1】:

从外观上看,这几行:

char *newName = new char[sizeof(name) + 1];
char *newLocation = new char[sizeof(location) + 1];

基本上什么都不做,因为locationname 字符串没有分配甚至写入,这可能是问题的根源。但是,您的 acresrating 应该已正确构造。

这是我创建的工作版本(ideone here -> http://ideone.com/v98zpq)

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

class Winery

public:
    Winery(const char * const name, const char * const location, const int acres, const int rating) :
        name(strdup(name)),
        location(strdup(location)),
        acres(acres),
        rating(rating)
    
    

    virtual ~Winery(void)
    
        free(name);
        free(location);
    

    const char * const getName() const  return name; 
    const char * const getLocation() const  return location; 
    const int getAcres() const  return acres; 
    const int getRating() const  return rating; 

private:
    char    *name;
    char    *location;
    int     acres;
    int     rating;
;

struct Node

    Node(const Winery& winery);
    Winery item;
;

Node::Node(const Winery& winery) :
    item(winery.getName(), winery.getLocation(), winery.getAcres(), winery.getRating())



int main()

    Winery winery("Mission Hill Winery", "Kelowna, BC, Canada", 646, 4);

    Node node(winery);

    printf("%s\n", node.item.getName());
    printf("%s\n", node.item.getLocation());
    printf("%i\n", node.item.getAcres());
    printf("%i\n", node.item.getRating());

输出:

Mission Hill Winery
Kelowna, BC, Canada
646
4

【讨论】:

以上是关于构造函数中的 C++ 初始化列表的主要内容,如果未能解决你的问题,请参考以下文章

C++构造函数的初始化列表

C++中数组的构造函数初始化列表

C++初始化列表构造函数VS普通构造函数

为啥 C++ 列表初始化也会考虑常规构造函数?

C++:初始化成员变量(无参构造|有参构造|初始化列表)

C++ 初始化器列表功能:调用函数而不初始化成员?