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类:
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.类与类之间的关系 ------------------------------------------------- ...
随机推荐
- TextBox的值随dropdownlist值而变化
转自:http://bytes.com/topic/asp-net/answers/443065-textbox-value-change-select-other-item-dropdownlist ...
- PAT1021
给定一个k位整数N = dk-1*10k-1 + ... + d1*101 + d0 (0<=di<=9, i=0,...,k-1, dk-1>0),请编写程序统计每种不同的个位数字 ...
- Struts2 标签库与OGNL的使用
- iOS xmpp Openfire+spark环境搭建
配置这个遇到太多问题了,写下来分享 首先到官网下载openfire+spark 下载地址:http://www.igniterealtime.org/downloads/index.jsp
- POJ 2376:Cleaning Shifts(贪心)
题目大意:有n个奶牛,他们负责在长为t个时间点的时间内值班,每个时间点至少有一个在值班,每个奶牛有一段空闲时间可以值班,求满足要求所需最少奶牛数量,无法满足则输出-1. 分析: 将奶牛空闲时间段看成线 ...
- 蔬菜(vegetable)
蔬菜(vegetable) 题目描述 题目背景:您使用脚本刷出了上题游戏 998244353 关的最高分 (最优解),心满意足的准备点继续学习,忽然一条弹窗弹了出来:你想明白活着的意义吗?你想真正的. ...
- BestCoder 2nd Anniversary/HDU 5718 高精度 模拟
Oracle Accepts: 599 Submissions: 2576 Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 262144/26 ...
- python2.7运行出现的Warning: UnicodeWarning: Unicode equal comparison failed to convert both arguments to Unicode - interpreting them as being unequal
运行出现如下错误 uncode编码警告:在unicode等价比较中,把两个参数同时转换为unicode编码失败.中断并认为他们不相等. windows下的字符串str默认编码是ascii,而pytho ...
- [AGC06D] Median Pyramid Hard (玄学)
Description 现在有一个N层的方块金字塔,从最顶层到最底层分别标号为1...N. 第i层恰好有2i−1个方块,且每一层的中心都是对齐的. 这是一个N=4的方块金字塔 现在,我们首先在最底层填 ...
- 关于mysql编码问题
1 查看MySQL编码 SHOW VARIABLES LIKE 'char%';