如何:用 interior_ptr 关键字声明值类型 (C++/CLI)

interior_ptr 可用于值类型。

重要说明重要事项

此语言功能支持 /clr 编译器选项,但是,不会 /ZW 编译器选项。

示例

t19s4hxx.collapse_all(zh-cn,VS.110).gif说明

下面 C++/CLI 示例演示如何使用具有值类型的 interior_ptr 。

t19s4hxx.collapse_all(zh-cn,VS.110).gif代码

// interior_ptr_value_types.cpp
// compile with: /clr
value struct V {
   V(int i) : data(i){}
   int data;
};

int main() {
   V v(1);
   System::Console::WriteLine(v.data);

   // pointing to a value type
   interior_ptr<V> pv = &v;
   pv->data = 2;

   System::Console::WriteLine(v.data);
   System::Console::WriteLine(pv->data);

   // pointing into a value type
   interior_ptr<int> pi = &v.data;
   *pi = 3;
   System::Console::WriteLine(*pi);
   System::Console::WriteLine(v.data);
   System::Console::WriteLine(pv->data);
}

t19s4hxx.collapse_all(zh-cn,VS.110).gifOutput

1
2
2
3
3
3

示例

t19s4hxx.collapse_all(zh-cn,VS.110).gif说明

在值类型, this 指针计算结果为 interior_ptr。

在值类型 V的非静态成员函数体, this 是值是对象地址函数调用类型 interior_ptr<V> 的表达式。

t19s4hxx.collapse_all(zh-cn,VS.110).gif代码

// interior_ptr_value_types_this.cpp
// compile with: /clr /LD
value struct V {
   int data;
   void f() {
      interior_ptr<V> pv1 = this;
      // V* pv2 = this;   error
   }
};

示例

t19s4hxx.collapse_all(zh-cn,VS.110).gif说明

下面的示例演示如何使用地址有静态成员的运算符。

静态 Visual C++ 类型成员的地址为本机指针。,因为值类型成员在运行时堆中分配,并可由垃圾回收器,移动静态值类型成员的地址是托管指针。

t19s4hxx.collapse_all(zh-cn,VS.110).gif代码

// interior_ptr_value_static.cpp
// compile with: /clr
using namespace System;
value struct V { int i; };

ref struct G {
   static V v = {22}; 
   static int i = 23; 
   static String^ pS = "hello"; 
};

int main() {
   interior_ptr<int> p1 = &G::v.i;
   Console::WriteLine(*p1);

   interior_ptr<int> p2 = &G::i;
   Console::WriteLine(*p2);

   interior_ptr<String^> p3 = &G::pS;
   Console::WriteLine(*p3);
}

t19s4hxx.collapse_all(zh-cn,VS.110).gifOutput

22
23
hello

请参见

参考

interior_ptr (C++/CLI)