无法从 const char* 转换为 const char *&

cannot convert from const char* to const char *&

本文关键字:const char 转换      更新时间:2023-10-16

我正在VC++上编写一个简单的UTF8到WideStr函数。

#pragma once
#include <Windows.h>
#include <string>
using namespace std;
wstring UTF8toWide(const char*& in);

MtoW.cpp

#include "MtoW.h"
#include <string>
#include <cassert>
using namespace std;
wstring UTF8toWide(const char*& in) {
int size = MultiByteToWideChar(CP_UTF8, 0, in, -1, NULL, 0);
wchar_t* wide_str = new wchar_t[size];
int result_size = MultiByteToWideChar(CP_UTF8, 0, in, -1, wide_str, size);
assert(size == result_size);
return wstring(wide_str);
}

主.cpp

#include <string>
#include <iostream>
#include "MtoW.h"
using namespace std;
int main()
{
string s = "hi";
//s.c_str();
//const char* q = "abc";
//const char*& c = q;
wstring q = UTF8toWide(s.c_str()); //error 
}

我得到了cannot convert from const char* to const char *&错误,为什么?
s.c_str()是一种const char*类型,我的代码应该可以工作。

std::string::c_str返回的是一个右值,它不能绑定到对非常量(即const char*&(。

如果参数类型不会在UTF8toWide()中修改,则可以将参数类型更改为const char* inconst char* const & inin或者改用命名变量。

string s = "hi";
const char* c = s.c_str();
wstring q = UTF8toWide(c);

不能将非常量左值引用绑定到右值:

UTF8toWide(s.c_str());
^^^^^^^^^ this is rvalue

您需要左值:

const char* c = s.c_str();
std::wstring q = UTF8toWide(c); //ok

或通过删除引用来更改 UTF8toWide,const char* in就可以

除了更改功能外,您还必须解决由new运算符引起的内存泄漏。在退出函数之前调用delete[] wide_str;,或使用std::wstring开头:

std::wstring UTF8toWide(const char* in) 
{
if (!in)
return std::wstring(L"");
int size = MultiByteToWideChar(CP_UTF8, 0, in, -1, NULL, 0);
std::wstring ws(size, L'');
int result_size = MultiByteToWideChar(CP_UTF8, 0, in, -1, &ws[0], size);
assert(size == result_size);
return ws;
}
std::string s = u8"ελληνικά";
std::wstring q = UTF8toWide(s.c_str());

或将#include <codecvt>用于 C++11

wstring q = std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>>{ }.from_bytes(s);