重载std :: string构造函数

时间:2012-02-13 14:21:41

标签: c++ constructor-overloading

我可以重载std :: string构造函数吗?

我想创建一个构造函数,它接受std :: wstring并返回一个std :: string。它有可能吗?如何?

感谢。

4 个答案:

答案 0 :(得分:3)

  

我可以重载std :: string构造函数吗?

不,这需要更改std::string声明。

  

我想创建一个构造函数,它接受std :: wstring并返回一个std :: string。它有可能吗?如何?

您可以使用转换功能,例如:

std::string to_string(std::wstring const& src);

但是,您需要决定如何处理无法使用std::string的8位编码表示的符号:是将它们转换为多字节符号还是抛出异常。请参阅wcsrtombs功能。

答案 1 :(得分:2)

而是定义一个自由函数:

std::string func(const std::wstring &)
{
}

答案 2 :(得分:1)

不,您无法向std::string添加任何新构造函数。您可以做的是创建一个独立的转换功能:

std::string wstring_to_string(const wstring& input)
{
    // Your logic to throw away data here.
}

如果你(想你)希望自动发生这种情况,我强烈建议重新评估这个想法。当您最不期望wstringstring时,{{1}}会自动被视为{{1}},这会给您带来很大的麻烦。

答案 3 :(得分:0)

这不是正确的做法,而且我认为我在编码时已经吸了一些东西,但它解决了这个问题。检查最后一个函数`convert_str'。

#pragma once    

#include <memory>
#include <string>
#include <vector>

#include <boost/utility/enable_if.hpp>
#include <boost/type_traits/remove_const.hpp>
#include <boost/type_traits/remove_pointer.hpp>
#include <boost/type_traits/is_same.hpp>
#include <boost/mpl/logical.hpp>

template <typename Target, typename Source, typename cond>
struct uni_convert {
};

template <typename Target, typename Source > 
struct uni_convert<Target,Source,
    typename boost::enable_if< boost::is_same<Target, Source>, int >::type > {
    static Target doit(Source const& src) 
    {

        return src;
    }
};

template <typename Cond > 
struct uni_convert<std::string,std::wstring,
    Cond > {
    static std::string doit(std::wstring const& src) 
    {
        std::vector<char> space(src.size()*2, 0);
        wcstombs( &(*( space.begin() )), src.c_str(), src.size()*2 );
        std::string result( &(*( space.begin() )) );
        return result;
    }
};

template <typename Cond > 
struct uni_convert<std::wstring,std::string,
    Cond > {
    static std::wstring doit(std::string const& src) 
    {
        std::vector<wchar_t> space(src.size()*2, 0);
        mbstowcs( &(*( space.begin() )), src.c_str(), src.size()*2 );
        std::wstring result( &(*( space.begin() )) );
        return result;
    }
};

template< typename TargetChar >
std::basic_string< TargetChar > convert_str( std::string const& arg)
{
    typedef std::basic_string< TargetChar > result_t;
    typedef uni_convert< result_t, std::string, int > convertor_t;
    return convertor_t::doit( arg );
}