软件的一个驱动由于开发的年代比较久一些,使用的是非Unicode编码,而当前新的软件使用的是Unicode编码,于是将非Unicode驱动用于Unicode软件上时,就出现了问题!

  问题就出现在非Unicode与Unicode的转换过程中!

程序中使用了char数组以及TCHAR数组,而数组是以字符‘\0’为结束的。

请看下面的例子:

 C++ Code 
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"
#include <iostream>
#include <string>
#include <tchar.h>
#include <Windows.h>

using namespace std;

int _tmain(int argc, _TCHAR* argv[])
{
    char    szArray[MAX_AARRAY_LENGTH];
    TCHAR   tszArray[MAX_AARRAY_LENGTH];
    memset(&szArray, , sizeof(szArray));
    memset(&tszArray, , sizeof(tszArray));
    ; i < MAX_AARRAY_LENGTH; i++)
    {
        )
        {
            szArray[i] = 'a';
        }
        )
        {
            szArray[i] = 'b';
        }

)
        {
            szArray[i] = 'c';
        }
    }

//会被‘\0’截断,然后输出aaaaaaaaaaa
    cout << szArray << endl;
    
    //char[]转TCHAR[] 方法1
) ;  
    MultiByteToWideChar (CP_ACP, , tszArray, nLength) ;

//char[]转TCHAR[] 方法2
; i < MAX_AARRAY_LENGTH; i++)
    {
        TCHAR* ptchar = new TCHAR;
        *ptchar = '\0';
        MultiByteToWideChar(CP_ACP, );  
        tszArray[i] = *ptchar;
        delete ptchar;
    }

//TCHAR[]转char[] 方法1
, NULL, NULL );
    WideCharToMultiByte( CP_ACP, , szArray, nLen, NULL, NULL );

//TCHAR[]转char[] 方法2
; i < MAX_AARRAY_LENGTH; i++)
    {
        char* pchar = new char;
        *pchar = '\0';
        WideCharToMultiByte(CP_ACP, , NULL, NULL );
        szArray[i] = *pchar;
        delete pchar;
    }
    
    //会被‘\0’截断,然后输出aaaaaaaaaaa
    cout << szArray << endl;
    cout << tszArray << endl;

;
}

  char数组szArray的内容如下:可见,在数组长度范围内,分三个位置存储了不同的内容,但是在使用cout输出、sprintf、MultiByteToWideChar以及WideCharToMultiByte等时会将其在索引为12时遇到‘\0’被截断处理,导致只能保留第一部分位置的内容,从而造成数据的截断丢失

  原始数据:

  MultiByteToWideChar转换后的数据:

   我一直希望能够通过库函数以及API来解决此问题,但是它们均是遇到‘\0’则结束转换操作。

一种可行的做法是:遍历字符数组,单个字符转换后,再赋值给新的字符数组(简单好用!)。

见程序中: //char[]转TCHAR[] 方法2     //TCHAR[]转char[] 方法2,从而很好地完成此类字符数组的转换。

最新文章

  1. 最详细的hadoop2.2.0集群的HA高可靠的最简单配置
  2. C#中Validating和Validated事件
  3. 自定义底部tab
  4. table表格实现点击修改 PHP同步数据库 排序
  5. Python if..else
  6. hdu 1040 As Easy As A+B
  7. Android What is Application
  8. 初学JavaScript须知道的七件事
  9. FreeBSD简单配置SSH并用root远程登陆方法
  10. 射频识别技术漫谈(25)——Felica简介
  11. unity3d游戏开发学习之使用3dmax创建导弹模型
  12. .Net Core 权限验证与授权(AuthorizeFilter、ActionFilterAttribute)
  13. leecode第二百三十五题(二叉搜索树的最近公共祖先)
  14. python 近义词库包 synonyms 的使用
  15. 执行sql脚本保留操作日志
  16. Spring boot国际化
  17. lodash 学习资料
  18. 关于高并发下kafka producer send异步发送耗时问题的分析
  19. 配置iSCSI部署网络存储
  20. MongoDB树形结构表示法

热门文章

  1. KVM虚拟化学习笔记系列文章列表(转)
  2. 发布WebService 1.1
  3. OAuth 授权timestamp refused问题
  4. 你所不知道的 CSS 阴影技巧与细节 滚动视差?CSS 不在话下 神奇的选择器 :focus-within 当角色转换为面试官之后 NPOI 教程 - 3.2 打印相关设置 前端XSS相关整理 委托入门案例
  5. DevExpress中GridControl列转义的实现方法
  6. CentOS-6.5下安装navicat for mysql
  7. 安卓-APP安装后多个图标的解决
  8. Nfs实现linux下文件共享
  9. location ^~ /images/
  10. $q服务的使用