当前位置: 首页 > article >正文

MFC中 error C2440错误分析及解决方法

错误 3 error C2440: “初始化”: 无法从“char *”转换为“ATL::CStringT<wchar_t,StrTraitMFC_DLL<wchar_t,ATL::ChTraitsCRT<wchar_t>>>
网上搜了方法,说可以到项目属性中的字符集里面把“使用Unicode字符集”改为“使用多字符集”然后应用,我这边试了错误更多了,之前错误没了,但有新的错误…
然后我找到我错的地方是这样的:

	CString T1 = (char*)(_bstr_t)XMLNODE->nodeName;
	CString T2 = (char*)(_bstr_t)XMLNODE->text;

应该是char转换为CString这里不对,想了想可能版本原因(vs2013)导致,又搜了别的方法看到一条评论下说要把**(char)改为(TCHAR*)**,改完之后不报错了,但还是想找一下原因:
字符串相关类型定义:
Typedef 定义
CHAR char
PSTR 或 LPSTR char*
PCSTR 或 LPCSTR const char*
PWSTR 或 LPWSTR wchar_t*
PCWSTR 或 LPCWSTR const wchar_t*
例如:typedef wchar_t WCHAR;
Windows使用UTF-16编码表示Unicode字符,为了将其与8位ANSI字符区分,UTF-16称为宽符,**Unicode是首选字符编码因其支持所有字符集和语言。**可能因为这里不能随便改字符集吧。

Microsoft向Windows引入Unicode支持时,通过提供两组并行API缓解转换,一组用于ANSI字符串(例如SetWindowTextA),一组用于Unicode字符串(SetWindowTextW,一般建议使用Unicode版本,ANSI效率可能较低)

TCHARS:某些情况下根据目标平台为ANSI或Unicode字符串编译相同的代码提供将字符串映射到Unicode或ANSI的宏:
宏 Unicode ANSI
TCHAR wchar_t char
TEXT(“x”)或
_T(“x”) L"x" “x”

所以说,可能我的版本不支持转换的原因是使用ANSI的(char*),而使用TCHAR和wchar_t都是可以的,我尝试了一下,也没报错wchar_t使用


http://www.kler.cn/a/390320.html

相关文章:

  • jupyter notebook练手项目:线性回归——学习时间与成绩的关系
  • Springboot 注解缓存使用教程
  • 【汇编】x86汇编编程寄存器资源心中有数
  • 龙蜥Linux系统部署docker21.1.3版本
  • NLP三大特征抽取器:CNN、RNN与Transformer全面解析
  • ImportError: attempted relative import with no known parent package 报错的解决!
  • Google Go编程风格指南-介绍
  • 工业通信协议对比:OPC-UA、Modbus、MQTT、HTTP
  • The Input data type is inconsistent with defined schema
  • XHCI 1.2b 规范摘要(15)
  • 刷题统计(C语言)
  • 【Word2Vec】传统词嵌入矩阵训练方法
  • DataX任务:同步mysql数据到Elasticsearch,且Elasticsearch索引带有分词器
  • FPGA学习(10)-数码管
  • 工位管理新策略:Spring Boot企业级应用
  • 4-3-2.C# 数据容器 - Dictionary 扩展(Dictionary 存储对象的特性、Dictionary 与数组的转换)
  • 【爬虫分享】
  • PYTHON常用基础库-写算法
  • uni-app用户登录⑫
  • 千帆模型gpt智能聊天机器人
  • (2024最新完整详细版)Docker部署MinIO
  • Redis - 事务
  • arm64架构的linux 配置vm_page_prot方式
  • 测试用例设计方法之判定表
  • 使用Matlab建立决策树
  • 「QT」几何数据类 之 QVector3d 三维向量类