1

>>クラス内の演算子と演算子をテンプレート化したいのですが<<、文字列専用にしたいので、これを行いました。

    class sql_command
{
public:
    sql_command() { }

    explicit sql_command(std::string& cmd)
        : m_raw(cmd) {
    }

    inline sql_command& operator<<(const char * arg)
    {
        m_raw += arg;
        return *this;
    }

    inline sql_command& operator<<(const std::string& arg)
    {
        m_raw += arg;
        return *this;
    }

    template<typename T>
    inline sql_command& operator>>(const T arg)
    {
        m_raw += boost::lexical_cast<std::string>(arg);
        return *this;
    }

    inline std::string const& command() const {
        return m_raw;
    }

private:
    std::string m_raw;
};

template<>
inline sql_command& operator>> <std::string> (const std::string& arg) {
    m_raw += "'";
    m_raw += arg;
    m_raw += "'";
    return *this;
}

template<>
inline sql_command& operator>> <char*>(const char * arg) {
    m_raw += "'";
    m_raw += arg;
    m_raw += "'";
    return *this;
}

しかし、コンパイラエラーが発生しました。

1>.\main.cpp(83) : error C2912: explicit specialization; 'sql_command &operator >><std::string>(const std::string &)' is not a specialization of a function template
1>.\main.cpp(83) : error C2805: binary 'operator >>' has too few parameters

これらのエラーを修正するにはどうすればよいですか?

4

2 に答える 2

11

演算子テンプレートを特殊化する必要はありません。:を使用してオーバーロードを記述するだけstd::stringです。

class sql_command {
    /* ... */

    template<typename T>
    sql_command& operator>>(const T& arg) { 
        /* general purpose implementation */ 
    }

    sql_command& operator>>(const std::string& arg) { 
        /* special std::string implementation */ 
    }
};

関数テンプレートの特殊化は厄介なので、可能な限り避ける必要があります。詳細については、ハーブサッターの「関数テンプレートを専門にしない理由」を参照してください。

于 2011-02-24T05:52:12.930 に答える
2

クラス解決演算子を使用するのを忘れました::

template<>
inline sql_command& sql_command::operator>> <std::string> (const std::string& arg)
                      see this ^^ 

他の専門分野でもこれを行ってください!

または、 Jamesのアドバイスに従ってください。

于 2011-02-24T05:51:25.167 に答える