关于VS2005与EVC4.2的项目开发过程中的问题点滴

简介:         这段时间一直致力于嵌入式IOServer与嵌入式HMI的开发,这中间及牵扯C#与EVC通信的问题,也牵扯EVC本身开发遇到的一些问题。

        这段时间一直致力于嵌入式IOServer与嵌入式HMI的开发,这中间及牵扯C#与EVC通信的问题,也牵扯EVC本身开发遇到的一些问题。

        1、EVC与C#数据传递

        我是用EVC做DLL(MFC 扩展DLL),C#直接调用。

       这是EVC DLL的接口

       DLLEXPORT long WINAPI IOMReadData(LPTSTR,LPTSTR);         //读内存数据  变量名称  数据
       DLLEXPORT long WINAPI IOMWriteData(LPTSTR,LPTSTR);          //写内存数据  变量名称

       这是C#的接口声明

        [DllImport(@"/Storage Card/YFIOES.dll")]
        public static extern int IOMReadData(string strName, StringBuilder strData);
        [DllImport(@"/Storage Card/YFIOES.dll")]
        public static extern int IOMWriteData(string strName, string strData);

        这里面遇到几个有意思的问题:对于字符串类型一直是数据传递的问题频发地带,在EVC接口中声明CString 与 CString & 接口时发现字符串能传递下去,可是返不回来,声明成LPTSTR类型,发现如果C#接口为string ,则messagebox可以显示该字符串,但是传递到textbox控件中则为空,声明为StringBuilder则就没有任何问题。

       这里有一个需要注意的问题:当返回的字符串大于16个字长度时,如下声明StringBuilder strData=new StringBuilder(); 要修改为StringBuilder strData=new StringBuilder(255); 否则会报错,我就是在这个问题上调试了半天,我还以为我的DLL出问题了呢。

       2、EVC与INI文件

       在EVC中是不支持INI读写的API的,幸好有网络,查了一个,还挺好使。

DWORD CYFIOMEM::GetPrivateProfileString(LPCTSTR lpAppName,LPCTSTR lpKeyName,LPCTSTR lpDefault,LPTSTR lpReturnedString,DWORD nSize,LPCTSTR lpFileName )
{

  CFile iniFile;
  PBYTE pFileBuf;
  CString szBuf;
  DWORD dwLength;

  if( lpReturnedString == NULL )return 0;
  if( lpDefault ) {_tcscpy( lpReturnedString,lpDefault ); }
  else {_tcscpy( lpReturnedString,TEXT( "/0" )); }
 
  if (lpFileName == NULL ){return _tcslen( lpReturnedString );} 
  if(!iniFile.Open(lpFileName, CFile::modeRead)) {return _tcslen( lpReturnedString );}
 
  dwLength = iniFile.GetLength();
  if (dwLength == 0) { return _tcslen( lpReturnedString );}
  pFileBuf = new BYTE[dwLength + 2];
  if (pFileBuf == NULL) { return _tcslen( lpReturnedString );}
 
  memset(pFileBuf, 0x0, dwLength + 2);
  iniFile.Read((void *)pFileBuf, dwLength);
  iniFile.Close();
 
  if (pFileBuf[0] == 0xFF && pFileBuf[1] == 0xFE) {szBuf = (LPCWSTR)(pFileBuf + 2);}
  else
  {
   PTCHAR pszWideChar = new TCHAR[dwLength + 1];
   MultiByteToWideChar(CP_ACP, 0, (LPCSTR)pFileBuf, dwLength, pszWideChar, dwLength);
   szBuf = pszWideChar;
   delete pszWideChar;
  }
  delete pFileBuf;
 
  while (1)
  {
   CString szTemp;
   int nPos;
   if (szBuf.IsEmpty()) return _tcslen( lpReturnedString );
 
   nPos = szBuf.FindOneOf(TEXT("/r/n"));
   if (nPos == -1)
   {
    szTemp = szBuf;
    szBuf.Empty();
   }
   else
   {
    szTemp = szBuf.Left(nPos);
    szBuf = szBuf.Right(szBuf.GetLength() - nPos);
    szBuf.TrimLeft(TEXT("/r/n"));
   } 
   szTemp.TrimLeft(TEXT("/t "));
   szTemp.TrimRight(TEXT("/t "));
   if (szTemp.GetAt(0) == TEXT('[') && szTemp.GetAt(szTemp.GetLength() - 1) == TEXT(']'))
   {
    szTemp = szTemp.Right(szTemp.GetLength() - 1);
    szTemp = szTemp.Left(szTemp.GetLength() - 1);
    if (lpAppName == NULL)
    {
  return _tcslen( lpReturnedString );                
    }
    else if (szTemp.CompareNoCase(lpAppName) == 0)
    {
  while (1)
  {
   if (szBuf.IsEmpty()) {continue; }    
   nPos = szBuf.FindOneOf(TEXT("/r/n"));
   if (nPos == -1)
   {
    szTemp = szBuf;
    szBuf.Empty();
   }
   else
   {
    szTemp = szBuf.Left(nPos);
    szBuf = szBuf.Right(szBuf.GetLength() - nPos);
    szBuf.TrimLeft(TEXT("/r/n"));
   }
    
   nPos = szTemp.Find(TEXT("="));
   if (nPos == -1) {return _tcslen( lpReturnedString );}

   CString szTemp1;
   szTemp1 = szTemp.Left(nPos);
   szTemp1.TrimLeft(TEXT("/t "));
   szTemp1.TrimRight(TEXT("/t "));
   if (lpKeyName == NULL)  {return _tcslen( lpReturnedString  );}
   else if (szTemp1.CompareNoCase(lpKeyName) == 0)
   {
    szTemp1 = szTemp.Right(szTemp.GetLength() - nPos - 1);
    szTemp1.TrimLeft(TEXT("/t "));
    szTemp1.TrimRight(TEXT("/t "));
    _tcscpy( lpReturnedString,szTemp1 );
     
    return _tcslen( lpReturnedString );
   }
  }
    }
   }
  }
  return _tcslen( lpReturnedString );
}
    

       3、在EVC中宽字符是我最头疼的,建议最好多用CString,能有效回避该问题。

       在开发过程中一定还会遇到各种各样的问题,有时间再一一写来... ...

相关文章
|
2月前
|
敏捷开发 数据可视化 算法
瀑布模型大揭秘:如何用分段式开发轻松搞定软件项目?
瀑布模型是软件开发中最早的线性开发方法,由Winston W. Royce于1970年提出。该模型将项目分为需求分析、系统设计、实现、集成与测试、部署和维护六个阶段,每个阶段自上而下依次进行。尽管近年来敏捷开发备受推崇,但瀑布模型在需求明确、流程复杂的项目中仍具重要价值。本文将详细介绍瀑布模型的概念、主要阶段及步骤,并探讨如何使用项目管理工具如板栗看板,帮助团队高效协作。
33 0
|
3月前
|
中间件 测试技术 数据库
开发人员之软件开发流程八个步骤
软件开发流程是指软件开发设计的一般流程,包括软件的总体结构、模块的组成、功能的设计、程序的编译、调试、联调、测试等过程。
298 2
|
7月前
|
搜索推荐 JavaScript Java
项目开发过程中实际遇到的几个问题处理
项目开发过程中实际遇到的几个问题处理
188 2
|
Java 定位技术 图形学
Unity客户端开发优化要点
Unity客户端开发优化要点
|
测试技术 开发工具 数据库
《移动互联网技术》第十一章 Android应用工程案例: 掌握Android系统的需求分析和设计以及 Android项目的程序测试和版本管理方法
《移动互联网技术》第十一章 Android应用工程案例: 掌握Android系统的需求分析和设计以及 Android项目的程序测试和版本管理方法
136 0
|
前端开发
前端学习笔记202305学习笔记第二十三天-重构项目依赖安装
前端学习笔记202305学习笔记第二十三天-重构项目依赖安装
70 0
|
Oracle IDE Java
最详细的Android开发环境配置经验分享(包含配置过程中可能出现的问题及解决办法。繁琐的配置步骤是否是你头疼呢,详细配置步骤你值得拥有!)
最详细的Android开发环境配置经验分享(包含配置过程中可能出现的问题及解决办法。繁琐的配置步骤是否是你头疼呢,详细配置步骤你值得拥有!)
420 0
最详细的Android开发环境配置经验分享(包含配置过程中可能出现的问题及解决办法。繁琐的配置步骤是否是你头疼呢,详细配置步骤你值得拥有!)