共用方式為


編譯器錯誤 C3918

usage 需要 'member' 成為數據成員

C3918 可能會因為與事件相關的數個原因而發生。

範例

C3918 可能會發生,因為目前內容中需要類別成員。 下列範例會產生 C3918。

// C3918.cpp
// compile with: /clr /c
public ref class C {
public:
   System::Object ^ o;
   delegate void Del();

   event Del^ MyEvent {
      void add(Del^ev) {
         if ( MyEvent != nullptr) {}   // C3918
         if ( o != nullptr) {}   // OK
   }
   void remove(Del^){}
   }
};

如果您嘗試檢查 Null 的一般事件,也會造成 C3918 (事件名稱將不再提供事件的備份存放區委派直接存取權)。

下列範例會產生 C3918。

// C3918_2.cpp
// compile with: /clr /c
using namespace System;
public delegate int MyDel(int);

interface struct IEFace {
   event MyDel ^ E;
};

ref struct EventSource : public IEFace {
   virtual event MyDel ^ E;
   void Fire_E(int i) {
      if (E)   // C3918
         E(i);
   }
};

如果您不正確地訂閱事件,也可能會發生 C3918。 下列範例會產生 C3918。

// C3918_3.cpp
// compile with: /clr /c
using namespace System;

public delegate void del();

public ref class A {
public:
   event del^ e {
      void add(del ^handler ) {
         d += handler;
      }

      void remove(del ^handler) {
         d -= handler;
      }

      void raise() {
         d();
      }
   }

   del^ d;
   void f() {}

   A() {
      e = gcnew del(this, &A::f);   // C3918
      // try the following line instead
      // e += gcnew del(this, &A::f);
      e();
   }
};

int main() {
   A a;
}