char[]与TCHAR[]互相转换引发的一个问题!
软件的一个驱动由于开发的年代比较久一些,使用的是非Unicode编码,而当前新的软件使用的是Unicode编码,于是将非Unicode驱动用于Unicode软件上时,就出现了问题!
问题就出现在非Unicode与Unicode的转换过程中!
程序中使用了char数组以及TCHAR数组,而数组是以字符‘\0’为结束的。
请看下面的例子:
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
// cppunicode.cpp : Defines the entry point for the console application.
// #include "stdafx.h" using namespace std; int _tmain(int argc, _TCHAR* argv[]) ) //会被‘\0’截断,然后输出aaaaaaaaaaa //char[]转TCHAR[] 方法2 //TCHAR[]转char[] 方法1 //TCHAR[]转char[] 方法2 ; |
char数组szArray的内容如下:可见,在数组长度范围内,分三个位置存储了不同的内容,但是在使用cout输出、sprintf、MultiByteToWideChar以及WideCharToMultiByte等时会将其在索引为12时遇到‘\0’被截断处理,导致只能保留第一部分位置的内容,从而造成数据的截断丢失。
原始数据:
MultiByteToWideChar转换后的数据:
我一直希望能够通过库函数以及API来解决此问题,但是它们均是遇到‘\0’则结束转换操作。
一种可行的做法是:遍历字符数组,单个字符转换后,再赋值给新的字符数组(简单好用!)。
见程序中: //char[]转TCHAR[] 方法2 //TCHAR[]转char[] 方法2,从而很好地完成此类字符数组的转换。
最新文章
- 最详细的hadoop2.2.0集群的HA高可靠的最简单配置
- C#中Validating和Validated事件
- 自定义底部tab
- table表格实现点击修改 PHP同步数据库 排序
- Python if..else
- hdu 1040 As Easy As A+B
- Android What is Application
- 初学JavaScript须知道的七件事
- FreeBSD简单配置SSH并用root远程登陆方法
- 射频识别技术漫谈(25)——Felica简介
- unity3d游戏开发学习之使用3dmax创建导弹模型
- .Net Core 权限验证与授权(AuthorizeFilter、ActionFilterAttribute)
- leecode第二百三十五题(二叉搜索树的最近公共祖先)
- python 近义词库包 synonyms 的使用
- 执行sql脚本保留操作日志
- Spring boot国际化
- lodash 学习资料
- 关于高并发下kafka producer send异步发送耗时问题的分析
- 配置iSCSI部署网络存储
- MongoDB树形结构表示法
热门文章
- KVM虚拟化学习笔记系列文章列表(转)
- 发布WebService 1.1
- OAuth 授权timestamp refused问题
- 你所不知道的 CSS 阴影技巧与细节 滚动视差?CSS 不在话下 神奇的选择器 :focus-within 当角色转换为面试官之后 NPOI 教程 - 3.2 打印相关设置 前端XSS相关整理 委托入门案例
- DevExpress中GridControl列转义的实现方法
- CentOS-6.5下安装navicat for mysql
- 安卓-APP安装后多个图标的解决
- Nfs实现linux下文件共享
- location ^~ /images/
- $q服务的使用