Ошибка компилятора C2327
Символ : не является именем типа, статическим или перечислителем
Код в вложенном классе пытается получить доступ к члену заключающего класса, который не является именем типа, статическим элементом или перечислителем.
При компиляции с помощью /clr распространенные причины для C2327 — это свойство с тем же именем, что и тип свойства.
Следующий пример приводит к возникновению ошибки C2327:
// C2327.cpp
int x;
class enclose {
public:
int x;
static int s;
class inner {
void f() {
x = 1; // C2327; enclose::x is not static
s = 1; // ok; enclose::s is static
::x = 1; // ok; ::x refers to global
}
};
};
C2327 также может возникать, если имя типа скрыто именем члена:
// C2327b.cpp
class X {};
class S {
X X;
// try the following line instead
// X MyX;
X other; // C2327, rename member X
};
C2327 также может работать в этой ситуации, когда необходимо полностью указать тип данных параметра:
// C2327c.cpp
// compile with: /c
struct A {};
struct B {
int A;
void f(A a) { // C2327
void f2(struct A a) {} // OK
}
};
Следующий пример приводит к возникновению ошибки C2327:
// C2327d.cpp
// compile with: /clr /c
using namespace System;
namespace NA {
public enum class E : Int32 {
one = 1,
two = 2,
three = 3
};
public ref class A {
private:
E m_e;
public:
property E E {
NA::E get() {
return m_e;
}
// At set, compiler doesn't know whether E is get_E or
// Enum E, therefore fully qualifying Enum E is necessary
void set( E e ) { // C2327
// try the following line instead
// void set(NA::E e) {
m_e = e;
}
}
};
}
В следующем примере показано значение C2327, если свойство имеет то же имя, что и тип свойства:
// C2327f.cpp
// compile with: /clr /c
public value class Address {};
public ref class Person {
public:
property Address Address {
::Address get() {
return address;
}
void set(Address addr) { // C2327
// try the following line instead
// set(::Address addr) {
address = addr;
}
}
private:
Address address; // C2327
// try the following line instead
// ::Address address;
};