我想知道如何将std::tr1::array<unsigned char, 16>
转换为std::string
?
编译器总是报错,我已经尝试过以下方法:
std::tr1::array<unsigned char, 16> sss;
string(sss);
string asd(sss);
无论哪种方式,都可以使它正常工作...
unsigned char
使得这个问题变得棘手。如果你知道你的系统使用2s补码1字节8位unsigned char
和char
,并且从unsigned char
到char
的隐式转换符合你的要求(这些并不总是正确的!),并且你的数组缓冲区以null结尾(即第一个0
之后的字符应该被丢弃),那么这个函数就可以工作:
template<std::size_t N>
std::string to_string( std::array<unsigned char, N> const& arr ) {
std::string retval;
for( auto c : arr ) {
if (!c)
return retval;
retval.push_back(c);
}
return retval;
}
我在这里加入了一些关于数组可能会“满”并且缺少空终止符的偏执症。
如果您实际上想要所有16个unsigned char
,即使其中一些是null,您需要使用以下代码:
std::string str( arr.begin(), arr.end() );
应该使用从 unsigned char
到 char
的隐式转换。
如果隐式转换不能达到您想要的效果,并且您知道 array
的存储器实际上是一个 char
数组,即使它的类型是 unsigned char
,您需要进行一些重新解释转换。
对于以空值结尾的情况:
template<std::size_t N>
std::string to_string_helper( const char* buf ) {
std::string retval;
if (!buf)
return retval;
for ( const char* it = buf; it < (buf+N); ++it ) {
if (!*it)
return retval;
retval.push_back(*it);
}
return retval;
}
template<std::size_t N>
std::string to_string_2( std::array<unsigned char, N> const& arr ) {
return to_string_helper<N>( arr.data() );
}
template<std::size_t N>
std::string to_string_2( std::array<unsigned char, N> const& arr ) {
const char* str = reinterpret_cast<const char*>(arr.data());
return std::string( str, str+N );
}
只是为了明确,你知道这个转换是一种复制转换,对吧?
// if you want the whole fixed-size string including any nul characters
template <std::size_t N>
std::string fixed_array_to_string(std::tr1::array<unsigned char, N> const &array)
{
return std::string(reinterpret_cast<const char *>(&*array.begin()), N);
}
// if your array is nul-terminated
template <std::size_t N>
std::string nul_array_to_string(std::tr1::array<unsigned char, N> const &array)
{
return std::string(reinterpret_cast<const char *>(&*array.begin()));
}
&*
这个东西很丑,可以用 &array.front()
代替。
如果你确定将其解释为 char
是有意义的,那么你可以将其推广到任何类型的数组:
// if you want the whole fixed-size string including any nul characters
template <typename T, std::size_t N>
std::string fixed_array_to_string(std::tr1::array<T, N> const &array)
{
return std::string(reinterpret_cast<const char *>(&*array.begin()),
N * sizeof(T));
}
unsigned
。已经澄清了。我认为我理解了未定义行为的部分,但不确定。 - Yakk - Adam Nevraumontchar
和unsigned char
有什么关系? - Yakk - Adam Nevraumont