zoukankan      html  css  js  c++  java
  • Delphi7程序调用C#写的DLL解决办法(转)

    近来,因工作需要,必须解决Delphi7写的主程序调用C#写的dll的问题。在网上一番搜索,又经过种种试验,最终证明有以下两种方法可行:
        编写C#dll的方法都一样,首先在vs2005中创建一个“类库”项目TestDll,
    using System.Runtime.InteropServices;
    namespace TestDll
    {
    public interface  I TestClass
      {
         void YourProcedure(stirng param1);
    }
    [ClassInterface(ClassInterfaceType.None)]
    public class TestClass:I TestClass
    {
    public void YourProcedure (stirng param1);
    { //自己的代码    }
        }
    }
    完成之后,设置项目的属性“Make assembly COM-Visible”为选中状态。编译之后得到 TestClass.dll,把此dll放到Delphi主程序目录下。打开vs2005自带的工具“Visual Studio 2005命令提示”,输入
    Regasm  路径/TestClass.dll 向系统注册此dll。
    Delphi程序调用此Dll方式有两种:
    一、打开vs2005自带的工具“Visual Studio 2005命令提示”,输入 TlbExp  路径/TestClass.dll 得到一个TestClass.tlb 文件。打开Delphi,选择“Project”--“import type library”找到刚才的TestClass.tlb,点击 CreateUnit,向delphi中引入一个com接口。
    delphi 调用代码如下:
    var aClass: TestClass;
    begin
      aClass : =  CoTestClass.Create;
      aClass. YourProcedure ('参数');
    end;
    二、不需生成tlb文件,仿照调用Excel的方式。代码如下:
    var aClass: Variant;
    begin
      aClass:= CreateOleObject('TestDll.TestClass');
      aClass.YourProcedure ('参数');
    end;
    以上两种方法都可以调用成功,其中调用regasm.exe向系统注册dll是必需的。第一种方法需要生成tlb文件,并引入delphi中,操作繁琐,但可以看到接口的定义。第二种方法操作简单,但看不到接口的定义。

    ==============================================================

    本人用第二种方法已正常实现功能,但DLL中一些自动创建的方法无法在外部直接调用,需要DLL准备特定的接口函数

  • 相关阅读:
    升级windows 11小工具
    windows 10更新升级方法
    您需要了解的有关 Oracle 数据库修补的所有信息
    Step by Step Apply Rolling PSU Patch In Oracle Database 12c RAC Environment
    Upgrade Oracle Database Manually from 12.2.0.1 to 19c
    如何应用版本更新 12.2.0.1.210420(补丁 32507738 – 2021 年 4 月 RU)
    xtrabackup 安装、备份和恢复
    Centos_Lvm expand capacity without restarting CentOS
    Centos_Lvm_Create pv vg lv and mount
    通过全备+relaylog同步恢复被drop的库或表
  • 原文地址:https://www.cnblogs.com/bayzhang/p/5162757.html
Copyright © 2011-2022 走看看