但是使用Dll中的导出类(或变量)的问题还没有解决,如果是用.NET环境下的开发语言生成的Dll,可以将欲导出类的源文件编译为.dll,然后用添加引用的方法直接使用,一个简单的小例子如下:
  csc /target:library DllSample.cs 最后生成DllSample.dll
  然后在使用时这样,右键点击解决方案资源管理器的"引用"->"添加引用",浏览加入DllSample.dll即可使用DllSample.cs命名空间中的类。
  但是对于利用VC++编写生成的Dll,添加引用方法是不能使用的,会提示:“未能添加对‘....dll’的引用。这不是有效的程序集或COM组件。只有具有.dll后缀名的程序或COM组件才能被引用。请确保该文件可访问,并是一个有效的程序集或COM组件”同理对于系统目录System32下的包含Win32API的Dll文件也不可按上法调用。
  利用System.Runtime.InteropService中的DllImport属性,就可以调用:
// package my Dll's functions in this class,hehe
// thanks goes to Knight94() brotherclass DllSample
{

[DllImport("DllSample1.DLL", EntryPoint="Add",  SetLastError=true,
 CharSet=CharSet.Auto,
 CallingConvention=CallingConvention.StdCall)]
public static extern int Add(int a,int b); [DllImport("DllSample1.DLL", EntryPoint="ShowString", 
                   SetLastError=true,
 CharSet=CharSet.Auto,
 CallingConvention=CallingConvention.StdCall)]
public static extern void ShowString();
}

解决方案 »

  1.   

    但是对于DllSample1中的导出类来说,好像就没有办法用了。
    请见帮助:
    DllImport 属性用于指定包含外部方法的实现的 dll 位置。namespace System.Runtime.InteropServices
    {
       [AttributeUsage(AttributeTargets.Method)]
       public class DllImportAttribute: System.Attribute
       {
          public DllImportAttribute(string dllName) {...}
          public CallingConvention CallingConvention;
          public CharSet CharSet;
          public string EntryPoint;
          public bool ExactSpelling;
          public bool PreserveSig;
          public bool SetLastError;
          public string Value { get {...} }
       }
    }
    准确地说,DllImport 属性具有下列行为: 它只能放置在方法声明上。 
    它具有单个定位参数:指定包含被导入方法的 dll 名称的 dllName 参数。 
    它具有五个命名参数: 
    CallingConvention 参数指示入口点的调用约定。如果未指定 CallingConvention,则使用默认值 CallingConvention.Winapi。 
    CharSet 参数指示用在入口点中的字符集。如果未指定 CharSet,则使用默认值 CharSet.Auto。 
    EntryPoint 参数给出 dll 中入口点的名称。如果未指定 EntryPoint,则使用方法本身的名称。 
    ExactSpelling 参数指示 EntryPoint 是否必须与指示的入口点的拼写完全匹配。如果未指定 ExactSpelling,则使用默认值 false。 
    PreserveSig 参数指示方法的签名应当被保留还是被转换。当签名被转换时,它被转换为一个具有 HRESULT 返回值和该返回值的一个名为 retval 的附加输出参数的签名。如果未指定 PreserveSig,则使用默认值 true。 
    SetLastError 参数指示方法是否保留 Win32“上一错误”。如果未指定 SetLastError,则使用默认值 false。 
    它是一次性属性类。  各位看到了:DllImport只能放置在方法声明上,那么我想导入VC++的类该怎么办呢?
     请各位帮忙一下,up也有分!不胜感激。
      

  2.   

    关注ing
    我现在是要调用c写的一个dll中的方法
    本来一知半解,看了楼主写的,明白了很多,谢谢至于怎么调用dll的内裤,我也很想知道,up先
      

  3.   

    强烈关注,这几天把我弄的头痛,怎么也不能调用FORTRAN编写的DLL,为什么啊????
    急急急!!!
      

  4.   

    其实,我在写.net程序的时候,也遇到这样的问题,觉得以前调用Dll很方便的,而现在则不是很好,不管是vc.net、c#、vb.net都一样。而这些麻烦事主要是声明的问题,这方面.net有一些帮助,还有一些Sample,有空看看Microsoft Visual Studio .NET\FrameworkSDK\Samples\Technologies\Interop\PlatformInvoke\WinAPIs\中的例子吧,会有些启发。
      

  5.   

    >>如何在C#中使用Dll(用VC++ 6.0编写)中的导出类明确告诉你不能,使用导出函数很简单因为是函数列表所以dllimport就够了如果是类,因为要加载MFC的运行时,别说C#了,就算BCB或Delphi也没法用C++编译器编译的是纯二进制代码,那里的类,你反汇编看看.一般是classname_funname(this)//函数的名字加上类名才隐晦的传递一个this指针之所以能在MFC中导出类,原因很简单.是在MFC的RTTI中的类型型录中加入类的连表(MFC通过宏来实现),这样你才可以导出和动态创建类.这个导出的DLL实际是叫做扩展DLL(MFC中的标准叫法),如果你非要用到托管中去那么可以以使用VC7写一个托管的DLL(因为VC7可以包括MFC7因此可以使用MFC的RTTI)