一周工作小结之CString以及GetPrivateProfileString()相关知识

一周工作小结之CString以及GetPrivateProfileString()相关知识

  本周在老板的带领下开始了对相关业务代码的尝试,主要工作内容还是在VC 6.0下进行MFC的相关开发,主要内容为获取本地机器与柜台机器的网络通信内容,具体来说就是对字符串的操作以及牵扯到相关MFC控件的使用,下面对这一周以来的开发内容进行相应的总结,主要体现在两个方面,一是CString的使用,二是对GetPrivateProfilesString()这一函数的相关理解。

一、CString的相关知识

  首先介绍一下,CString是MFC下自带的类,类似于String类,在实际工作过程中主要运用到CString的截取以及CString与LPCTSTR、LPSTR的相关转化问题。首先来说明CString的截取方法:Left(),Right(),Mid()。

  eg.CString str = "aabbccdd";

  str.Left(4) = "aabb";//从左起第一位开始往右截取四位

  str.right(4) = "ccdd";//截取字符串的后4位

  str.mid(2)="bbccdd";//从字符串索引位2的位置往右截取

  str.mid(2,3) = "bbc";//从字符串索引为2的位置向后截取3位

  下面说明CString与LPCTSTR、LPSTR的相互转化:

  首先,我们应该了解的是,LPCTSTR就相当于const char*,LPSTR相当于char*。

  CString与LPCTSTR:

  CString str = "aabb";

  const char *lpcstr = (LPCTSTR)str;//CString转LPCTSTR

  CString cstr = lpctstr;//LPCTSTR转CString

  再重新转化为CString则需要:CString str(lpcstr);

  CString与LPSTR:

  LPSTR str = "aabb";

  CString cstr;

  cstr.Format("%s",str);//LPSTR转CString

  再转化为LPSTR:(LPSTR)(LPCSTR)cstr;//转化完后cstr即为LPSTR类型。

二、对GetPrivateProfileString()这一函数的相关理解

  GetPrivateProfileString()的函数原型:DWORD GetPrivateProfileString(LPCTSTR lpAppName,LPCTSTR lpKeyName,LPCTSTR lpDefaut,LPSTR lpReturnedString,DWORD nSize,LPCTSTR lpFileName);

  我用该函数来读取提前配置好的ini文件,ini文件的构成如下图所示 

 

  其中[public]与[private]相当于函数参数中的lpAppName,而下面的102、aabb以及node就相当于参数中的lpKeyName,而lpDefaut则代表着一个默认值,当程序没有从文件中读取到数据时,就会以改值充当读取到的数据,可以设为空值,lpReturnedString是接收ini文件中=右边的字符串,如上图中"aaa,bbb,ccc"、"ccdd"、"ttt,kkk",我们需要提前定义一个字符串数组来接收这些字符串,nSize代表着该接收字符串数组的大小,所以我们应该针对读取到的内容,为接收信息的字符串数组设定合适的大小,最后一个lpFileName则是代表着ini文件的路径,笔者在这里建议小伙伴们可以借助于GetModuleFileName()函数,该函数的主要功能是获取指定模块的路径,笔者在这里用于获取可执行文件的路径,而ini文件就可以跟可执行文件放在同一目录下,这样就可以将lpFileName设置成绝对路径,在很多情况下可以避免设置成相对路径所带来的不必要的麻烦,比如读取不到文件等。而笔者在编码过程中,遇到了GetPrivateProfileString()失败的问题,经过各种检查,最后找到了原因,笔者代码如下图:

小伙伴们可以看到,笔者的GetPrivateProfileString()中第二个参数为lpctstr,是经过处理转化后得到的字符串,而处理后的字符串在内存中显示为:

"102

"

大家可以看到,上文的双引号并没有处于同一行中,也就代表着处理后的字符串中还包含了末尾的换行符,那么问题就来了,包含了换行符的字符串并不能与我设置的ini文件中的值相匹配,所以就造成了读取失败的现象,为此笔者花费了大量的时间检查,调试代码,最终问题出在了这个换行符上,这也是没有经验导致的,踩过一次坑,就会铭记于心。。。。。

 

以上是这周主要的工作内容总结,希望能对碰到类似问题的小伙伴提供帮助。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
纯c读写ini配置文件 用c/c++读写ini配置文件有不少第三方的开源库,如iniparser、libini、rwini、UltraLightINIParser等,但都不理想,往往代码较大、功能较弱、 接口使用不方便。尤其在大小写处理、前后空格、各种注释、跨平台换行符支持、带引号字符串处理、无section操作、原格式保持等方面存在问题。 现将本人精心制作的ini读写程序源码奉献给大家,纯c编写,简洁好用。支持windows和linux。 主要特点: 1、支持;和#注释符号,支持行尾注释。 2、支持带引号'或"成对匹配的字符串,提取时自动去引号。引号中可带其它引号或;#注释符。 3、支持无section或空section(名称为空)。 4、支持10、16、8进制数,0x开头为16进制数,0开头为8进制。 5、支持section、key或=号前后带空格。 6、支持\n、\r、\r\n或\n\r换行格式。 7、不区分section、key大小写,但写入时以新串为准,并保持其大小写。 8、新增数据时,若section存在则在该节最后一个有效数据后添加,否则在文件尾部添加。 9、支持指定key所在整行删除,即删除该键值,包括注释。 10、可自动跳过格式错误行,修改时仍然保留。 11、修改时保留原注释:包括整行注释、行尾注释(包括前面空格)。 12、修改时保留原空行。以上三点主要是尽量保留原格式。 不足之处: 1、不支持单key多value(逗号分割),只能一次性提取后自行处理。 2、不支持同名重复section和key。(重复section可视为错误,重复key则可能造成分歧) 3、不能提取所有section或key名称。 使用只需两个文件inirw.h、inirw.c,另有测试程序和工程文件,支持windows和linux。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值