专栏首页微卡智享C++创建动态库C#调用(二)----回调函数的使用

C++创建动态库C#调用(二)----回调函数的使用

前言

上一篇《C++创建动态库C#调用》我们练习了C++写的动态库用C#的调用方法,后来研究回调函数这块,就想练习一下回调函数的使用,学习并巩固一下,话不多说,我们直接开始。

代码演示

我们还是用上一章的那个Cppdll的Demo


C++动态库的修改

首先还是打开Cppdll.h的头文件,我们在头文件中定义一个回调函数

typedef int(*cb)(int, int);

然后在声明的导出函数中加入调用的这个cb指针

extern "C" int Cppdll_API call_func(cb callback, int a, int b);

如下图

接着我们再在Cppdll.cpp的源文件中写call_func的实现方法,方法也很简单,就是先求出输入的两个int类型的数值的和与差,然后把这两个值再做为回调参数的值传回去。

int Cppdll_API call_func(cb callback, int a, int b) { int c = AddCount(a, b); int d = abs(a - b); return callback(c, d); }

这样C++的动态库我们就已经完成了


C#的调用程序的修改

先写C++动态库的调用函数声明

[DllImport("Cppdll", EntryPoint = "call_func", CallingConvention = CallingConvention.StdCall)] public static extern int CallFun(Dllcallback dcb, int num1, int num2);

[UnmanagedFunctionPointer(CallingConvention.Cdecl)]

public delegate int Dllcallback(int num1, int num2);

上面的Dllcallback是我们定义的回调函数,这里必须用委托的方式定义,下面的【UnmanagedFunctionPointer里的CallingConvention.Cdecl】这个是必须要写上的,因为默认C++的指针都是Cdecl,如果这里不声明后调用时会默认_stdcall,在动态调用dll函数的时候,提示Run-Time Check Failure #0 -The value of ESP was not properly saved across a function call.

然后我们写一个回调的方法

public int Call(int a, int b) { textBox1.AppendText("回调函数第一个参数为:" + a + "\r\n"); textBox1.AppendText("回调函数第二个参数为:" + b + "\r\n"); return a + b; }

最后在原来的按钮事件最后接着写调用C++动态库的这个实现方法

textBox1.AppendText("调用C++动态库call_func回调函数\r\n"); num = CallFun(Call, num1, num2); textBox1.AppendText("得到两个数相加:" + num + "\r\n");

到这里C#调用程序的修改也已经完成了


运行一下程序看看效果

-END-

本文分享自微信公众号 - 微卡智享(VaccaeShare),作者:Vaccae

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-03-04

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • C++ OpenCV之鼠标响应事件

    在OpenCV中也存在鼠标的操作,今天我们先介绍一下鼠标中的操作事件,用于为之后的GrabCut分割来做个前提。

    Vaccae
  • LeetCode|560. 和为K的子数组--C++题解

    本题原本按我最喜欢的暴力破解提交的,结果到最后几个大数据的时候提示超时了,最后也是看了官方的思路,了解了动态规划的思路去解的这个题,所以本篇写了两个实现的方法。...

    Vaccae
  • C++ OpenCV视频操作之稠密光流对象跟踪

    我们在学习完稀疏光流跟踪完后,我们再学习一下稠密光流对象跟踪,稠密光流算法(即图像上所有像素点的光流都计算出来),由于要计算图像上所有点的光流,故计算耗时,速度...

    Vaccae
  • 树上莫队算法

    attack
  • 挑战程序竞赛系列(23):3.2折半枚举

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.n...

    用户1147447
  • codeforces329B(bfs)

    由于猎人事先知道我们行走的路线,所以猎人们可以先走到终点前等待,可以使用bfs预处理出终点到各个点之间的距离,如果猎人到终点的距离小于等于我们从起点到终点的距离...

    dejavu1zz
  • 2017.5.20欢(bei)乐(ju)赛解题报告

    预计分数:100+20+50=first 实际分数:20+0+10=gg 水灾(sliker.cpp/c/pas) 1000MS  64MB 大雨应经下了几天雨...

    attack
  • C++ 万字长文第一篇---拿下字节面试

    有些情况下,基类生成的对象是不合理的,比如动物可以派生出狮子、孔雀等,这些派生类显然存在着较大的差异。那么可以让基类定义一个函数,并不给出具体的操作内容,让派生...

    syy
  • LeetCode 323. 无向图中连通分量的数目(并查集)

    给定编号从 0 到 n-1 的 n 个节点和一个无向边列表(每条边都是一对节点),请编写一个函数来计算无向图中连通分量的数目。

    Michael阿明
  • BZOJ3143: [Hnoi2013]游走(期望DP 高斯消元)

    Description 一个无向连通图,顶点从1编号到N,边从1编号到M。  小Z在该图上进行随机游走,初始时小Z在1号顶点,每一步小Z以相等的概率随机选 择当...

    attack

扫码关注云+社区

领取腾讯云代金券