这是我在用C#开发IOServer遇到的一个问题,该程序需要用到原先用MFC开发的DLL,最大问题是该dll运行过程中的一些信息,通过window消息向指定的hwnd(窗体句柄)发送数据。数据的指针放在WParam参数里,LParam参数是数据的类型信息。

     C#提供  m.GetLParam()函数,可惜我的数据放在WParam参数里(这个还不能修改,否则原有程序就无法运行了,修改的代价太高),所以这个函数不能用。

    下面经过多次测试,终于获取数据成功。

   MFC DLL中的相关代码:

  

   
   
   
   
  1. TCHAR cMessage[255];  
  2.  SYSTEMTIME stime;  
  3.     GetLocalTime(&stime);  
  4.   swprintf(cMessage,_T("%04d-%02d-%02d %02d:%02d:%02d [%-16s #%03d] - %s "),stime.wYear,stime.wMonth,stime.wDay,stime.wHour,stime.wMinute,stime.wSecond,strSource,lngNO,strMessage);  
  5.        if (G_IOMRun.lngMsgFlag==0)  
  6.  {  
  7.      SendMessage(G_IOMRun.Hwnd, WM_USER+7722,(long)cMessage,lngType); //  
  8.  }  

  在C#中需要重载窗体的消息处理函数,相关代码如下:

     

   
   
   
   
  1. [DllImport("kernel32", EntryPoint = "CopyMemory")]  
  2.         public static extern void CopyMemory(StringBuilder Destination,IntPtr Source,int Length);  
  3.         ///   
  4.         /// 重载窗口函数  
  5.         ///   
  6.         ///   
  7.         protected override void WndProc(ref Message m)  
  8.         {  
  9.             //---------------------  
  10.             if(m.Msg == 0x0400 + 7722)  
  11.             {                
  12.                StringBuilder strData = new StringBuilder(255);  
  13.                CopyMemory(strData, m.WParam, 255);  
  14.                ShowInfo((int)m.LParam,strData.ToString());  
  15.             }  
  16.             //---------------------  
  17.             base.WndProc(ref m);  
  18.         }  

注意:CopyMemory函数的声明需要自己修改(原声明如下),一定要去掉“ref” 关键字,否则会获取不正确。

 

   
   
   
   
  1. [DllImport("kernel32", EntryPoint="CopyMemory")]  
  2. public static extern void CopyMemory (  
  3.         ref int Destination,  
  4.         ref int Source,  
  5.         int Length  
  6. );  
  7.