description | title | ms.date | f1_keywords | helpviewer_keywords | ms.assetid |
---|---|---|---|---|---|
Learn more about: Compiler Error C2079 |
Compiler Error C2079 |
11/04/2016 |
C2079 |
C2079 |
ca58d6d5-eccd-40b7-ba14-c003223c5bc7 |
Compiler Error C2079
‘identifier’ uses undefined class/struct/union ‘name’
The specified identifier is an undefined class, structure, or union.
This error can be caused by initializing an anonymous union.
The following sample generates C2079:
// C2079.cpp // compile with: /EHsc #include <iostream> int main() { std::ifstream g; // C2079 }
Possible resolution:
// C2079b.cpp // compile with: /EHsc #include <fstream> int main( ) { std::ifstream g; }
C2079 can also occur if you attempt to declare an object on the stack of a type whose forward declaration is only in scope.
// C2079c.cpp class A; class B { A a; // C2079 }; class A {};
Possible resolution:
// C2079d.cpp // compile with: /c class A; class C {}; class B { A * a; C c; }; class A {};
Think about the computer’s memory for a second here.
class B;
class A {
byte aa;
B ab;
};
class B {
byte bb;
A ba;
};
A x;
Now the question the compiler needs to answer is How much space should I reserve for x
?
Let’s see. The first byte of x
is byte aa;
. Easy enough. That’s 1 byte.
Next comes B ab;
. Let’s see what’s in there.
The first byte of x.ab
is a byte bb;
. That’s 2 bytes for x
so far.
Next, is a A ba;
. Let’s see what’s in there.
The first byte of x.ab.ba
is a byte aa;
. That’s 3 bytes for x
so far.
And so on and so forth ad infinitum.
How big is x
? The correct answer is of course *** OUT OF CHEESE ERROR ***
.
The compiler doesn’t actually do this because it knows it can’t handle this case — so the syntax doesn’t allow circular containment in the first place.
Here’s a diagram of the contents of x
in this example:
UPDATE
Apparently, I forgot to include a solution here. Now that you understand what the problem is, the solution should be pretty simple. Use pointers. Either use a pointer from A
to B
and let B
include A
as it already does, or vice versa, or use two pointers. Then, you won’t have circular inclusion — if B
doesn’t include a copy of A
but just a pointer to it, that fixes the entire issue here.
- Remove From My Forums
-
Question
-
Good Morning all,
I encountered a compiler error c2079 which said «use of undefined class/struc/union name» and am not sure how to solve it. The following is a simplified setup of classes inside my code:
class a;
class b {
int b1;
public :
func1();
}
b::func1()
{
a aclass;
aclass.a1() <== this is where error c2079 come from. a1 is a public function of class a
}
I search Microsoft C++ compiler error web. It suggests that using pointer to a, instead of instance of a. So I changed
a aclass to a * aclass = NULL;
and
aclass.a1() to aclass->a1();
The compiler error changed to c2027 : use of undefined type ‘a’
Any suggestions? Thanks for your help.
Tom Lin
Answers
-
I would suggest to split class interface (to be put in .h files) from class implementation (to be put in .cpp file).
So, you should have 4 files:
ClassA.h (header containing interface of class A)
ClassA.cpp (implementation of class A)
ClassB.h (header containing interface of class B)
ClassB.cpp (implementation of class B)
The implementation of B::func1 method should be put in ClassB.cpp file.
The implementation of A::a1 method should be put in ClassA.cpp file.
At the beginning of ClassB.cpp file, you should add a #include «ClassA.h» because you are using class A.
See if this helps…
Giovanni
-
Marked as answer by
Thursday, May 6, 2010 6:41 PM
-
Marked as answer by
Сообщение от kuroiryuu
имеется описание классов в h-файле
C++ | ||
|
при компиляции вылазит две ошибки
error C2558: class ‘Node’ : no copy constructor available or copy constructor is declared ‘explicit’
error C2079: ‘Node::neighbors_’ uses undefined class ‘AdjacencyList’
подскажите как бороться с этими ошибками?
по C2079 пробовал описать переменную Node::neighbors_ как
C++ | ||
|
ошибка исчезла, но такое использование указателя не самый лучший способ, хотелось бы узнать как правильно в данной ситуации применить std::auto_prt<AdjacencyList>
У вас возникает ошибка потому, что в классе Node, когда вы определяете член класса AdjacencyList neighbors_;, компилятору не известно определение этого типа, то есть AdjacencyList Вы лишь предварительно объявили этот класс, но не определили, а компилятору, чтобы правильно определить класс Node, нужно знать размер класса AdjacencyList . То есть в этом месте тип AdjacencyList является неполным типом: компилятор не имеет информации о его размере. Когда же вы это поле заменили указателем, то компилятору не нужно само строение класса AdjacencyList , так как размер указателя компилятору в любом случае известен.
Во-втором случае при объявлении функции
C++ | ||
|
проблема заключается в том, что в классе Node вы объявили конструктор копирования следующим образом
то есть вы передаете не константную ссылку в качестве аргумента. А на временные объекты можно ссылаться только по константной ссылке. То есть компилятор не нашел подходящего конструктора копирования и выдал сообщение об ошибке.
То есть чтобы было понятно, ваша функция
C++ | ||
|
в качестве возвращаемого значения создает временный объект Node, а соответствующий конструктор копирования вида
C# | ||
|
отсутствует!
- Remove From My Forums
-
Question
-
Good Morning all,
I encountered a compiler error c2079 which said «use of undefined class/struc/union name» and am not sure how to solve it. The following is a simplified setup of classes inside my code:
class a;
class b {
int b1;
public :
func1();
}
b::func1()
{
a aclass;
aclass.a1() <== this is where error c2079 come from. a1 is a public function of class a
}
I search Microsoft C++ compiler error web. It suggests that using pointer to a, instead of instance of a. So I changed
a aclass to a * aclass = NULL;
and
aclass.a1() to aclass->a1();
The compiler error changed to c2027 : use of undefined type ‘a’
Any suggestions? Thanks for your help.
Tom Lin
Answers
-
I would suggest to split class interface (to be put in .h files) from class implementation (to be put in .cpp file).
So, you should have 4 files:
ClassA.h (header containing interface of class A)
ClassA.cpp (implementation of class A)
ClassB.h (header containing interface of class B)
ClassB.cpp (implementation of class B)
The implementation of B::func1 method should be put in ClassB.cpp file.
The implementation of A::a1 method should be put in ClassA.cpp file.
At the beginning of ClassB.cpp file, you should add a #include «ClassA.h» because you are using class A.
See if this helps…
Giovanni
-
Marked as answer by
Thursday, May 6, 2010 6:41 PM
-
Marked as answer by