A * a = new a()
以上两种方式皆可实现类的实例化,有new的区别在于:
1.前者在堆栈中分配内存,后者为动态内存分配,在一般应用中是没有什么区别的,但动态内存分配会使对象的可控性增强。
2.不加new在堆栈中分配内存
3.大程序用new,小程序直接申请
4.只是把对象分配在堆栈内存中
5.new必须delete删除,不用new系统会自动回收内存
你所说的属于“反射”的知识点,反射在 Java、.NET 都是被支持的,并不是所有语言都支持,如:C++ 就没有反射的说法。“反射”其实就是利用程序集的元数据信息。
反射可以有很多方法,编写程序时请先导入 System.Reflection 命名空间,假设你要反射一个 DLL 中的类,并且没有引用它(即未知的类型):
Assembly assembly = Assembly.LoadFile("程序集路径,不能是相对路径")// 加载程序集(EXE 或 DLL)
object obj = assembly.CreateInstance("类的完全限定名(即包括命名空间)")// 创建类的实例
若要反射当前项目中的类可以为:
Assembly assembly = Assembly.GetExecutingAssembly()// 获取当前程序集
object obj = assembly.CreateInstance("类的完全限定名(即包括命名空间)")// 创建类的实例,返回为 object 类型,需要强制类型转换
也可以为:
Type type = Type.GetType("类的完全限定名")
object obj = type.Assembly.CreateInstance(type)
=======================================================
补充:
1)反射创建某个类的实例时,必须保证使用类的完全限定名(命名空间 + 类名)。Type.GetType 方法返回 null 则意味搜索元数据中的相关信息失败(反射失败),请确保反射时使用类的完全限定名。
2)反射功能十分强大,没有什么不能实现的。若实现你所说的“跨程序集”,请使用我给的第一种方法创建类的实例,并反射该实例的字段、属性、方法、事件... 然后动态调用之。
可以传入类实例的句柄或者指针。按你的例子DLL参数用LPVOID,那么进入函数体后,用 CLink* pPCLink= (CLink*)lpThreadParameter获取实例的指针,然后继续你预想的工作。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)