解决方案 »

  1.   

    不需要改直接调用
    http://www.cnblogs.com/my-blog/archive/2008/11/14/1333454.html
      

  2.   

    [DllImport(...)] 
    public  static extern  Int32  XCIdentify( IntPtr  point,byte b1,byte b2 ,byte b3);
    一般写在你使用这个函数的范围内就可以了,比如声明在某个类里面就可以拿他当作C#中你自己写的方法一般使用。
      

  3.   

    又出现个问题:DLLImport线面有蓝色波浪线,显示:找不到类型或命名空间名称“DLLImport”(是否缺少using指令或程序集引用?)
    各位仁兄,这又是怎么回事呢?应该怎么改呢?
      

  4.   


    添加引用
    using System.Runtime.InteropServices;
      

  5.   

    我那个头文件里面的HANDLE,下面也有蓝色的波浪线,错误说明:找不到类型或命名空间名称“HANDLE”(是否缺少using指令或程序集引用?),大家知道这又是怎么回事吗?应该怎么解决呢?
      

  6.   

    用 IntPtr t 代替 HRESULT tHRESULT 是 C++ 的句柄, 和 C# 的 IntPtr 对应 System.IntPtr t=HRESULT; 
      

  7.   

    用到HANDLE的地方换上IntPtr不就行了
      

  8.   

    A DllImport只能放置在方法声明上
    B DllImport具有单个定位参数:指定包含被导入方法的 dll 名称的 dllName参数
    C DllImport具有五个命名参数:
    a、CallingConvention 参数指示入口点的调用约定。如果未指定 CallingConvention,则使用默认值 CallingConvention.Winapi。    
     b、CharSet 参数指示用在入口点中的字符集。如果未指定 CharSet,则使用默认值 CharSet.Auto。   
     c、EntryPoint 参数给出 dll 中入口点的名称。如果未指定 EntryPoint,则使用方法本身的名称。    
     d、ExactSpelling 参数指示 EntryPoint 是否必须与指示的入口点的拼写完全匹配。如果未指定 ExactSpelling,则使用默认值 false。    
     e、PreserveSig 参数指示方法的签名应当被保留还是被转换。当签名被转换时,它被转换为一个具有 HRESULT 返回值和该返回值的一个名为 retval 的附加输出参数的签名。如果未指定 PreserveSig,则使用默认值 true。    
     f、SetLastError 参数指示方法是否保留 Win32"上一错误"。如果未指定 SetLastError,则使用默认值 false。
    D它是一次性属性类
    E此外,用 DllImport 属性修饰的方法必须具有 extern 修饰符
    [DllImport("dllforvc.dll", EntryPoint = "GSMModemGetErrorMsg", CharSet = CharSet.Ansi,CallingConvention = CallingConvention.StdCall)]
    public static extern string GSMModemGetErrorMsg();