CLI/C++中混合类的使用【转】
http://www.cppblog.com/mzty/archive/2007/12/24/39517.html
CLI/C++中混合类的使用
一 混合类
所谓混合类是指CLI/C++中native的Class中可以包含CLR对象,CLR的class也可以包含Naitve的对象。
1)native的class中包含CLR对象,必须通过gcroot<>或auto_gcroot<>。
2)CLR中的class中包含native的对象,必须是指针,也可以使用高手写的CAutoNativePtr智能指针。
注意:C#中不能调用CLI/C++中的Native的class。同样Native C++中也不能调用CLI/C++中的Ref的class。
二 实例
高手的CAutoNativePtr类:
Author : Nishant Sivakumar
Email : voidnish@gmail.com
Blog : http://blog.voidnish.com
Web : http://www.voidnish.com 
You may freely use this class as long as you include
this copyright.
You may freely modify and use this class as long
as you include this copyright in your modified version. 
This code is provided "as is" without express or implied warranty.
Copyright ?Nishant Sivakumar, 2006.
All Rights Reserved.
***/
#pragma once
template<typename T> ref class CAutoNativePtr
{
private:
T* _ptr;
public:
CAutoNativePtr() : _ptr(nullptr)
{
}
CAutoNativePtr(T* t) : _ptr(t)
{
}
CAutoNativePtr(CAutoNativePtr<T>% an) : _ptr(an.Detach())
{
}
template<typename TDERIVED>
CAutoNativePtr(CAutoNativePtr<TDERIVED>% an) : _ptr(an.Detach())
{
}
!CAutoNativePtr()
{
delete _ptr;
}
~CAutoNativePtr()
{
this->!CAutoNativePtr();
}
CAutoNativePtr<T>% operator=(T* t)
{
Attach(t);
return *this;
}
CAutoNativePtr<T>% operator=(CAutoNativePtr<T>% an)
{
if(this != %an)
Attach(an.Detach());
return *this;
}
template<typename TDERIVED>
CAutoNativePtr<T>% operator=(CAutoNativePtr<TDERIVED>% an)
{
Attach(an.Detach());
return *this;
}
static T* operator->(CAutoNativePtr<T>% an)
{
return an._ptr;
}
static operator T*(CAutoNativePtr<T>% an)
{
return an._ptr;
}
T* Detach()
{
T* t = _ptr;
_ptr = nullptr;
return t;
}
void Attach(T* t)
{
if(t)
{
if(_ptr != t)
{
delete _ptr;
_ptr = t;
}
}
else {#ifdef _DEBUG throw gcnew Exception( "Attempting to Attach() a nullptr!");#endif } } void Destroy() { delete _ptr; _ptr = nullptr; }};测试实例之CLI/C++文件:

#pragma once
#include <string>
#include <iostream>
#include <gcroot.h>
#include <msclr/auto_gcroot.h>
#include "AutoNative.h"
using namespace System;
namespace MixedNativeAndCLIDLL {
public class NativeClass
{
public:
int *pX;
NativeClass(){pX = new int(10);}
~NativeClass()
{
if(pX != NULL)
{
delete pX;
pX = NULL;
}
}
};
public ref class RefClass
{
public:
int x;
RefClass(){x = 20;}
};
public class MixedClass0
{
public:
NativeClass nativeClass;
//RefClass refClass; // error c3265 and error c3149
gcroot<RefClass^> refClass1;
std::string nativeStr;
//System::String refStr; // error c3265 and error c3149
gcroot<System::String^> refStr1;
MixedClass0()
{
refClass1 = gcnew RefClass();
refStr1 = gcnew System::String("i am a native class mixed some clr members.\n");
}
~MixedClass0()
{
delete refClass1;
delete refStr1;
}
void PrintSelf()
{
System::Console::WriteLine("my name is MixedClass0");
System::Console::WriteLine(refClass1->x);
System::Console::WriteLine(refStr1);
}
};
public class MixedClass1
{
public:
NativeClass nativeClass;
//RefClass refClass; // error c3265 and error c3149
msclr::auto_gcroot<RefClass^> refClass1;
std::string nativeStr;
//System::String refStr; // error c3265 and error c3149
msclr::auto_gcroot<System::String^> refStr1;
MixedClass1()
{
refClass1 = gcnew RefClass();
refStr1 = gcnew System::String("i am a native class with some clr members.\n");
}
~MixedClass1()
{
// no need to delete. } void PrintSelf() { System::Console::WriteLine("my name is MixedClass1"); System::Console::WriteLine(refClass1->x); System::Console::WriteLine(refStr1); } }; public ref class MixedClass2 { public: //NativeClass nativeClass; // error c4368 NativeClass * nativeClass1; RefClass^ refClass; //std::string nativeStr; // error c4368 std::string *nativeStr1; System::String^ refStr; // MixedClass2() { nativeClass1 = new NativeClass(); nativeStr1 = new std::string("i am a clr class with some native members.\n"); } ~MixedClass2() { delete nativeClass1; delete nativeStr1; } !MixedClass2(){} void PrintSelf() { System::Console::WriteLine("my name is MixedClass2"); std::cout<<*(nativeClass1->pX)<<std::endl; std::cout<<*nativeStr1<<std::endl; } }; public ref class MixedClass3 { public: //NativeClass nativeClass; // error c4368 CAutoNativePtr<NativeClass> nativeClass1; RefClass^ refClass; //std::string nativeStr; // error c4368 CAutoNativePtr<std::string> nativeStr1; System::String^ refStr; // MixedClass3() { nativeClass1 = new NativeClass(); nativeStr1 = new std::string("i am a clr class with some native members.\n"); } ~MixedClass3(){} !MixedClass3(){} void PrintSelf() { System::Console::WriteLine("my name is MixedClass3"); std::cout<<*(nativeClass1->pX)<<std::endl; std::cout<<*nativeStr1<<std::endl; } };}测试实例之C#调用文件:
using System.Text;
namespace CsharpTest
{
class Program
{
static void Main(string[] args)
{
MixedNativeAndCLIDLL.MixedClass0 mixedClass0 = new MixedNativeAndCLIDLL.MixedClass0();
//mixedClass0.PrintSelf();
MixedNativeAndCLIDLL.MixedClass1 mixedClass1 = new MixedNativeAndCLIDLL.MixedClass1();
//mixedClass1.PrintSelf();
MixedNativeAndCLIDLL.MixedClass2 mixedClass2 = new MixedNativeAndCLIDLL.MixedClass2();
mixedClass2.PrintSelf();
MixedNativeAndCLIDLL.MixedClass3 mixedClass3 = new MixedNativeAndCLIDLL.MixedClass3();
mixedClass3.PrintSelf();
}
}
}
三 代码下载
CLI/C++中混合类的使用【转】的更多相关文章
- JS中定义类的方法
JS中定义类的方式有很多种: 1.工厂方式 function Car(){ var ocar = new Object; ocar.color = "blue" ...
- sass中 混合宏 VS 继承 VS 占位符 各自的使用时机和特点
初学者都常常纠结于这个问题“什么时候用混合宏,什么时候用继承,什么时候使用占位符?”其实他们各有各的优点与缺点,先来看看他们使用效果: a) Sass 中的混合宏使用 举例代码见 2-24 行 编译出 ...
- css编译工具Sass中混合宏,继承,占位符分别在什么时候使用
//SCSS中混合宏使用 @mixin mt($var){ margin-top: $var; } .block { @include mt(5px); span { display:block; @ ...
- JS中定义类的方法<转>
转载地址:http://blog.csdn.net/sdlfx/article/details/1842218 PS(个人理解): 1) 类通过prototype定义的成员(方法或属性),是每个类对象 ...
- Python中的类属性、实例属性与类方法、静态方法
1.什么是类对象,实例对象 类对象:类名 实例对象:类创建的对象 2.类属性就是类对象所拥有的属性,它被所有类对象的实例对象所共有,在内存中只存在一个副本,这个和C++.Java中类的静态成员变量有点 ...
- Processing中PImage类和loadImage()、createImage()函数的相关解析
聊一聊Processing中PImage类和loadImage().createImage()函数.因为要借P5做多媒体创意展示,图片是一个很重要的媒体.有必要就图片的获取和展放作总结. 首先 有一点 ...
- 11.mixins混合类
一.混合类(mixins) 使用基于类的视图,最大的优势之一就创建可复用的代码 我们编写的非常类似的代码,可以抽象出来,将这部分代码放到mixin类系列中,然后作为父类提供子类继承使用 from ...
- Python中的类、对象、继承
类 Python中,类的命名使用帕斯卡命名方式,即首字母大写. Python中定义类的方式如下: class 类名([父类名[,父类名[,...]]]): pass 省略父类名表示该类直接继承自obj ...
- 基础知识(05) -- Java中的类
Java中的类 1.类的概念 2.类中的封装 3.对象的三大特征 4.对象状态 5.类与类之间的关系 ------------------------------------------------- ...
随机推荐
- redhat-2
2016年5月16日-工作日志1 通过PXE安装RHEL7.2系统,部署satellite6.2(采用不是least-stable版本,是Satellite-6.2.0-RHEL-7-20160512 ...
- [译]pandas .at 和.loc速度对比
df.at 一次只能访问一个值. df.loc能够选取多行多列. In [25]: %timeit df.loc[('a', 'A'), ('c', 'C')] 10000 loops, best o ...
- MySql 存储过程实例(附完整注释)(转)
MySql 存储过程实例(附完整注释) 将下面的语句复制粘贴可以一次性执行完,我已经测试过,没有问题! MySql存储过程简单实例: ...
- 用最优方法从LinkedList列表中删除重复元素
用运行速度最优的方法从LinkedList列表里删除重复的元素,例如A->B->BB->B->C,返回A->B->BB->C. 考试的时候没完全想明白,考完又 ...
- BZOJ2123 [Sdoi2013]森林 【主席树 + 启发式合并】
题目 输入格式 第一行包含一个正整数testcase,表示当前测试数据的测试点编号.保证1≤testcase≤20. 第二行包含三个整数N,M,T,分别表示节点数.初始边数.操作数.第三行包含N个非负 ...
- Cmake——CMake+SVN或Hg生成版本号
CMake+SVN或Hg生成版本号 原来的CMake需要用shell脚本生成SVN版本号,再作为cmake参数传入.CMake调用脚本示例: #!/bin/sh # cmake.sh ServerCo ...
- docker (centOS 7) 使用笔记6 - skydns
skydns被用于kubenets作为DNS服务.本次测试是单独使用skydns作为DNS服务器,且作为loadbalance使用. 前提:需要先安装配置etcd服务 (在前面的文章里,已经安装部署了 ...
- RSA DSA
RSA https://blog.csdn.net/sunmenggmail/article/details/11994013 https://baike.baidu.com/item/RSA%E7% ...
- sys.modules[__name__]
A way to get a handle to the current running module in Python: import sys module = sys.modules[__nam ...
- 简单实现UIlabel可复制功能
作者 Sunshine_tt 关注 在我们日常的开发中经常会遇到一些小需求,比如需要长按控件来拷贝控件中得内容.我们知道在iOS中有三个控件自身是支持拷贝,粘贴的,如:UITextField,UITe ...