Форум программистов, компьютерный форум CyberForum.ru

Доступ к обобщенным вложенным структурам - C++

Восстановить пароль Регистрация
 
Ataman
 Аватар для Ataman
1 / 1 / 1
Регистрация: 27.10.2011
Сообщений: 33
17.12.2012, 22:53     Доступ к обобщенным вложенным структурам #1
Добрый Вечер. Подскажите пожалуйста как получить доступ ко вложенной структуре в main.cpp. Проблема с областью видимости Node (inner struct) в main.
есть обобщенный класс со вложенной структурой в BinaryTree.h :

Модераторам: Перенесите пожалуйста эту тему в раздел C++ для экспертов. Спасибо.

C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
// simple binary tree
template <class T> class BinaryTree 
{
    template <class U>  struct Node 
    {
        Item<U> item; // holds data
        Node<U> *left, *right; // references to childs
        Node<U> *p; // reference to parent
    };
    Node<T> *root;
public:
    BinaryTree(); // default constructor
    Node<T>* newNode(Node<T> *father, const Item<T>&); // creates new node with data
    int BinaryTree<T>::depth(Node<T> *node); // Compute the depth of a node
    .....
    .....
};
Функции класса которые используют Node реализованы в .cpp файле без проблем осуществляется доступ к Node :

C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include "BinaryTree.h"
 
// receives tree, father node, key. creates new Node with data and return it
template <class T> 
typename BinaryTree<T>::Node<T>* BinaryTree<T>::newNode(Node<T> *father, const Item<T> &other)
{
    BinaryTree<T>::Node<T> *node = (BinaryTree<T>::Node<T>*)malloc(sizeof(BinaryTree<T>::Node<T>));
    ..................
}
 
// Compute the depth of a node
template <class T>
int BinaryTree<T>::depth(Node<T> *node) 
{
    ..................
}
 
 
// initialized only for oppurtunity of separation declaration & initiation of template class in multiple files
template Item<char>;
template BinaryTree<char>;

А вот тут проблема с областью видимости - main.cpp :

C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
// receives string in infix mode and reproduce the tree using postfix & infix data
template <class Q> BinaryTree<Q> RestoreTree(char*);
template <class T> void RestoreSubTree(char*, char*, BinaryTree<T>::Node<T>*, int);
 
void main()
{
    BinaryTree<char>::Node<char> n('c');  // ОШИБКА
}
 
// receives string in infix mode and reproduce the tree using postfix & infix data
template <class Q> 
BinaryTree<Q> RestoreTree(char *infix)
{
    char *postfix = ConvertToPostfix(infix);
 
    BinaryTree<char> tree;
    // reproduce the tree by recursive function
    RestoreSubTree(infix, postfix, tree.root, strlen(infix));
 
    return tree;
}
 
// НЕТУ ДОСТУПА К NODE
template <class T>
void RestoreSubTree(char *infix, char *postfix, BinaryTree<T>::Node<T> *node, int len)
{
    .......
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.12.2012, 22:53     Доступ к обобщенным вложенным структурам
Посмотрите здесь:

C++ вопрос по структурам
C++ Программа по структурам!
C++ влпрос по структурам
C++ структура с вложенным массивом структур
программа по структурам C++
C++ подскажите с обобщенным програмированием
C++ Задача по вложенным циклам
C++ Шаблон очереди с приоритетом и вложенным классом

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 15:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru