C++的回调函数中有一个参数是,是返回一个字符串,原则如下: 
typedef   void   (*TDataEvent)(char   *AData   ,int   ALen); 
其中char   *AData是从DLL中返回一个字符串,串的内存已经在DLL中分配了

下面中我在C#中定义的委托 
public   delegate   void   TDataEvent(Byte[]   AData,   int   ALen);

下面是回调函数的设置代码: 
Event   =   new   clReceivelDllPoxy.TDataEvent(getDate); 
ReceDllPoxy.AddServer(1024,   Event,   2); 
其中   Event是上面委托的实例,我定义成一个成员这样就不会被自己释放

下面是C#中回调函数的实现 
public   void   getDate(byte[]   AData,   int   ALen) 

//发现每次回调是   AData只有一个字节 
}

using System;
using System.Collections.Generic;
using System.Text;
using System.Runtime.InteropServices;
using System.Reflection;
using System.Reflection.Emit; namespace AppDllTest
{
/// <summary>
/// 非托管动态调用基类,基类不能直接使用,需要实现 FunTable()的虚函数
/// </summary>
public abstract class clDllBasePoxy
{
//-装入DLL---------
public bool Open(string dllFileName)
{
Hand = LoadLibrary(dllFileName);
if (Hand == )
{
return false;
} FunSet(GetFunTable());
return true;
}
//-关闭DLL---
public bool Close()
{
return FreeLibrary(Hand)!=;
}
public abstract string[] GetFunTable(); //函数对应表由外部代理类通过 GetFunTable来设置 #region //调用Windows32下的Kernele32库中的装入函数来完成对非托管DLL的引用-------
//--------------------------------------------------------------
[DllImport("Kernel32")]
private static extern int GetProcAddress(int handle, String funcname);
[DllImport("Kernel32")]
private static extern int LoadLibrary(String funcname);
[DllImport("Kernel32")]
private static extern int FreeLibrary(int handle);
private int Hand = ; //DLL的句柄
private static Delegate GetAddress(int dllModule, string functionname, Type t) //把指针转变成C#的代理
{
int addr = GetProcAddress(dllModule, functionname);
if (addr == )
{
return null;
}
else
{
return Marshal.GetDelegateForFunctionPointer(new IntPtr(addr), t);
}
}
//--关联代理和DLL中的函数-----------
private bool FunSet(string[] aFun)
{
Type tp = this.GetType();
string[] Value;
for (int i = ; i < aFun.Length; i++)
{
Value = aFun[i].Split(','); //"Box, TBox, _Box" 第一项是代理的实例名,第二项是代理的定义名,第三项是DLL中的函数名
if (Value.Length == )
{
FieldInfo fi = tp.GetField(Value[].Trim()); //找实例
Type type = tp.GetNestedType(Value[].Trim());//找尾托
if (fi != null && type != null)
{
fi.SetValue(this, GetAddress(Hand, Value[].Trim(), type)); //创建关联
}
}
}
return true;
}
#endregion
} public class clDllPoxy : clDllBasePoxy
{
public override string[] GetFunTable()
{
string[] FunTable = new string[]{
"GetFixParamCount, TGetFixParamCount, _GetFixParamCount",
"GetFixParam, TGetFixParam, _GetFixParam"
};
return FunTable;
} //--输出函数----------------------------------------------
public TGetFixParamCount GetFixParamCount;
public TGetFixParam GetFixParam;
//--代理描述----------------------------------------------
public delegate int TGetFixParamCount(); //获取固定参数个数
public delegate bool TGetFixParam(int AIndex, byte []AOutBuf); //固定参数
} /// <summary>
/// C#动态调用托管DLL的基类--------------
/// </summary>
public class clNetDllPoxy
{
//--装入动态库----------
public bool Open(string dllFileName, string className)
{
FAsembly = Assembly.LoadFrom(dllFileName);
if (FAsembly == null)
{
return false;
} Type type = FAsembly.GetTypes()[]; //第一个对应的名字空间当成是调用的名字空间
FDllName = dllFileName;
FClassName = className;
if (type != null)
{
FNameSpace = type.Namespace;
}
return true;
} //--设置Dll中的函数范围---------
public void SetArea(string nameSpace, string className)
{
FNameSpace = nameSpace;
FClassName = className;
}
//--调用指定的方法,注:方法的所有参数都转化成对象类型
public object Invoke(string funName, object[] ObjArray_Parameter)
{
try
{
Type[] types = FAsembly.GetTypes();
foreach (Type tp in types)
{
if (tp.Namespace == FNameSpace && tp.Name == FClassName)
{
MethodInfo metInfo = tp.GetMethod(funName);
if (metInfo != null)
{
object obj = Activator.CreateInstance(tp); //创建类对象
if (obj != null)
{
return metInfo.Invoke(obj, ObjArray_Parameter);
}
}
}
}
}
catch
{ }
return null; } private Assembly FAsembly; //Dll的程序集
private string FDllName;
private string FNameSpace;
private string FClassName;
} }

C#调用C++回调函数的问题的更多相关文章

  1. [Effective JavaScript 笔记]第67条:绝不要同步地调用异步的回调函数

    设想有downloadAsync函数的一种变种,它持有一个缓存(实现为一个Dict)来避免多次下载同一个文件.在文件已经被缓存的情况下,立即调用回调函数是最优选择. var cache=new Dic ...

  2. DLL与EXE之间的通讯调用 以及 回调函数的线程执行空间

    dll 与 exe 之间的通讯方式有很多种, 本文采用回调函数的方法实现, 本文也将研究多线程,多模块的情况下,回调函数所在的线程, 啥也不说了,先附上代码: 下面的是dll模块的的, dll的工程文 ...

  3. setInterval调用ajax回调函数不执行的问题

    setInterval调用ajax回调函数不执行 1.首先检查你的setInterval()函数写法是否正确 参考写法 // 检查是否支付成功 var isPayRequest=false; var ...

  4. 理解 JavaScript 回调函数并使用

    JavaScript中,函数是一等(first-class)对象:也就是说,函数是 Object 类型并且可以像其他一等对象(String,Array,Number等)一样使用.它们可以"保 ...

  5. VC++ 回调函数及使用方法(转)

    转载:http://blog.csdn.net/vsooda/article/details/7435801 转载:http://blog.csdn.net/lincyang/article/deta ...

  6. Mina、Netty、Twisted一起学(九):异步IO和回调函数

    用过JavaScript或者jQuery的同学都知道,JavaScript特别是jQuery中存在大量的回调函数,例如Ajax.jQuery的动画等. $.get(url, function() { ...

  7. js中的回调函数的理解和使用方法

    js中的回调函数的理解和使用方法 一. 回调函数的作用 js代码会至上而下一条线执行下去,但是有时候我们需要等到一个操作结束之后再进行下一个操作,这时候就需要用到回调函数. 二. 回调函数的解释 因为 ...

  8. JS回调函数(callback)

    在使用Jquery的时候,用到Callback(),回调函数的概念.而且很多. 比如: $.ajax({ url:"test.json", type: "GET" ...

  9. C#将C++动态库的回调函数封装成事件

    关于C#调用C++动态库的文章很多,调用动态库中回调函数的方法也不在少数.但大多数调用回调函数的方法依然保留了C++的语法特点. 比如有一段C++的回调函数代码,为了表达它的意思,我把注释也粘贴了进来 ...

随机推荐

  1. POJ 2688 Cleaning Robot

    题意: 给你一个n*m的图.你从'o'点出发,只能走路(图中的'.')不能穿墙(图中的'x'),去捡垃圾(图中的' * ')问最少走多少步能捡完所有垃圾,如有垃圾捡不了,输出-1. 思路: 有两个思路 ...

  2. Apache 虚拟主机 配置方法

    打开httpd.conf文件 去掉LoadModule vhost_alias_module modules/mod_vhost_alias.so前面的#号 去掉Include conf/extra/ ...

  3. buf.readInt16LE函数详解

    offset {Number} 0 noAssert {Boolean} 默认:false 返回:{Number} 从该 Buffer 指定的带有特定尾数格式(readInt16BE() 返回一个较大 ...

  4. java的原子变量

    java的原子变量类似c++的InterlockedDecrement()操作.其实就是在进行算术时,把整个算式看为一个整体,并且保证同一时间只计算该式子一次. 它的用途比如,多个线程可能会调用某个函 ...

  5. 【SQL】约束

    1. 添加约束 1)使用ALTER TABLE语句 •添加或删除约束,不会修改其结构 •启用和禁用约束 •通过使用MODIFY子句添加NOTNULL约束 ALTER TABLE <table_n ...

  6. java反射_01

    为什么要用反射? 举个栗子: package com.imooc.reflect; public class Work { // 定义一个word方法 public void word() { Sys ...

  7. QS之force(3)

    Example in project - First force signals in certain time and then noforce signals after some time. # ...

  8. spring 回顾

    主要就是它的IOC理念 即:把对象的创建.初始化.销毁等工作交给spring容器来做 依赖jar

  9. webpack核心提炼

    基本是学习的时候在网上整理的资料,并非自己原创,这篇文章的的主要目的是记录webpack.config.js的配置方式.可能也有不少错误,欢迎指正!! 一.应用场景 前端模块化开发.功能拓展.css预 ...

  10. javaee Properties键值对写入和读取方法

    package Zjshuchu; import java.util.Properties; import java.util.Set; public class Demo03 { public st ...