Я знаю кодировку и что входная строка на 100% однобайтовая, никаких причудливых кодировок, таких как utf и т. Д. И все, что я хочу, — это преобразовать ее в wchar_t * или wstring на основе известной кодировки. Какие функции использовать? btowc()
а потом кругом? Возможно, в строковых объектах есть что-то полезное. Есть много примеров, но все они для «многобайтовых» или причудливых циклов с btowc (), которые только показывают, как отображать вывод на экране, что действительно эта функция работает, я не видел ни одного серьезного примера, как работать с буферами в таких Ситуация, всегда широкий символ в 2 раза больше, чем одна строка символов?
Попробуй это шаблон. Это послужило мне очень хорошо.
(автор неизвестен)
/* string2wstring.h */
#pragma once
#include <string>
#include <vector>
#include <locale>
#include <functional>
#include <iostream>
// Put this class in your personal toolbox...
template<class E,
class T = std::char_traits<E>,
class A = std::allocator<E> >
class Widen : public std::unary_function<
const std::string&, std::basic_string<E, T, A> >
{
std::locale loc_;
const std::ctype<E>* pCType_;
// No copy-constructor, no assignment operator...
Widen(const Widen&);
Widen& operator= (const Widen&);
public:
// Constructor...
Widen(const std::locale& loc = std::locale()) : loc_(loc)
{
#if defined(_MSC_VER) && (_MSC_VER < 1300) // VC++ 6.0...
using namespace std;
pCType_ = &_USE(loc, ctype<E> );
#else
pCType_ = &std::use_facet<std::ctype<E> >(loc);
#endif
}
// Conversion...
std::basic_string<E, T, A> operator() (const std::string& str) const
{
typename std::basic_string<E, T, A>::size_type srcLen =
str.length();
const char* pSrcBeg = str.c_str();
std::vector<E> tmp(srcLen);
pCType_->widen(pSrcBeg, pSrcBeg + srcLen, &tmp[0]);
return std::basic_string<E, T, A>(&tmp[0], srcLen);
}
};
// How to use it...
int main()
{
Widen<wchar_t> to_wstring;
std::string s = "my test string";
std::wstring w = to_wstring(s);
std::wcout << w << L"\n";
}
Других решений пока нет …