我刚刚开始使用C ++,并且在理解类中私有成员变量的作用域如何工作方面遇到了一些问题。请参阅以下代码

class Foo{
    private:
        std::vector<int> container;
    public:
        // other methods
};

int main(int argc, char* argv[])
{
    Foo* foo = new Foo;
    // other method calls to which foo is passed
    delete foo;
    return 0;
}

在上面的代码中,变量<!> quot; container <!> quot;是一个私有成员变量。我正在调用<!>“; Foo <!>”;实例并将其传递给其他几个方法和类。以下是我的疑惑

  1. 变量<!>“容器<!>”的范围是什么?在删除实例foo后,该变量是否存在?
  2. 我是否需要制作<!> quot; container <!>;作为向量的指针?
  3. 感谢您的帮助

有帮助吗?

解决方案

  1. 是的,只要包含它的对象存在,容器成员的生命周期就会持续存在,直到你在指向它的指针上调用deletefoo在你的案件)。
  2. 不,没有理由这样做。使它成为指针需要您创建一个vector<int>的动态对象,您需要管理它的生命周期(包括在容器指针上调用delete)。这不必要。假设您希望容器的持续时间与Foo对象一样长,您可以直接包含它,而无需使用指针。
  3. 传递<=>指针只会传递指针。它指向的对象将被复制,只有指向它的指针才会被复制。如果您了解Java,那么如果我告诉您传递指针与仅仅传递对Java中对象的引用相同,那么它可以帮助您,比如说:

    Foo f = new Foo();
    // just passes the reference (pointer in C++) to doIt. 
    // the actual object is not copied
    doIt(f);
    

其他提示

我正在调用<!>“; Foo <!>”;实例

实际上,您正在创建类Foo 的实例。

具体来说,您是通过 new()从堆中分配一块内存。这个内存块足够大,可以包含 Foo :: container 以及 Foo 所需的其他开销类。

(在这个例子中,没有。对于其他类,可能还有其他属性或虚拟指针表。)

当然, new()会调用(可能是默认的?) Foo :: Foo()构造函数,而构造函数又会初始化 Foo :: container 通过 std :: vector 构造函数。

变量<!>“容器<!>”的范围是什么?

容器是实例 foo 的属性[component]。只要实例 foo 存在,它就存在。

范围方面,我们可以说 Foo :: container 。但是如果没有类 Foo 的实例,则无法访问 Foo :: constainer 。 (例如,对象 foo 。) Foo :: constainer 在没有类 Foo 的实例时不存在。

(有些类变量的工作方式有所不同,其中一个值在所有实例中共享。但这不是这种情况。)

此范围 IRRELEVANT 到您的公共/受保护/私人/朋友成员访问控制。

例如,在某些 Foo :: myPublicMethod()中,您可以引用 Foo :: container 。虽然您也可以在这种情况下放弃显式范围,只需将其称为容器

请注意,保密,您无法访问 Foo 方法之外的 Foo :: container

在删除实例foo之前,该变量是否存在?

我是否需要制作<!> quot; container <!>;作为向量的指针?

没有。你可以,但你当然不必。

一般来说,我建议不要在构造函数中使用new作为指针的类实例成员,并在析构函数中删除。这是低效和麻烦的。 (默认的复制构造函数可以复制指针值,然后析构函数可以删除相同的指针值两次。)


根据您的需要,您可以考虑:

int main(int argc, char* argv[])
{
  Foo foo;
  // other method calls to which foo is passed
  return 0;
}
返回0; 后,

foo 将超出范围,并自动删除。而且, foo 将从堆栈而不是堆中分配。


您可能会发现带注释的C ++参考手册的已用副本。它很旧,但它具有很高的信噪比。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top