从头文件定义嵌套类

时间:2017-05-21 07:06:46

标签: c++ templates inner-classes generic-programming class-constructors

C ++仍然相当新,并试图在这里提升一个档次。我想构建一个带有嵌套Node类的Heap类,并向Heap类添加堆排序方面。我已经用Java做了类似的事情,但是我试图在.cpp文件中定义嵌套类时遇到困难。

#pragma once
#ifndef HEAP_H
#define HEAP_H

template <class T>
class Heap 
{

public:

    class Node
    {
    public:
        Node(T);
        T data;

    private:
        Node *parent;
        Node *left_child;
        Node *right_child;
        boolean is_root;
    };


    Heap(T*, int);
    sort_it();


private:
    T *unsorted_list
    Node root;
    void build_heap();
    void add_node(Node);
    void swap_root();
    void trickle_down();
    void heap_sort();
};


#endif

现在,当我在.cpp文件中定义我的嵌套类时,我不能简单地...

#include "stdafx.h"
#include "Heap.h"
#include <iostream>

//Defining Heap Constructor
Heap::Heap(T* incoming_array, int _size)
    {
         unsorted_list = incoming_array;
         size = _size;
    }

//Defining Node Constructor
Heap::Node(T _data)
    {
        data = _data;
        left_child = right_child = parent = Null;
        is_root = false;
    }

我不确定我的问题是我如何合并模板,或者我的定义内部类的语法是错误的。在C ++中我不熟悉泛型编程和嵌套类

1 个答案:

答案 0 :(得分:1)

如果在嵌套类中使用任何泛型类型,则必须指定模板。

template<class T>
class Node

在类外定义模板类构造函数

template<typename T>
Node<T>::Node(T _data)

声明成员如下,

Node<T> root