3

我正在尝试将 boost.thread 与 metrowerks codewarrior 5.5.3 一起使用;在标头 thread.hpp 中,我收到他正在重新定义 thread::thread_data 的错误:

class BOOST_THREAD_DECL thread
{
private:
    ...        
    template<typename F>
    struct thread_data:
        detail::thread_data_base
    {
        F f;

        thread_data(F f_):
            f(f_)
        {}
        thread_data(detail::thread_move_t<F> f_):
            f(f_)
        {}

        void run()
        {
            f();
        }
    };
    ...
 };

template<typename F>
struct thread::thread_data<boost::reference_wrapper<F> >:
    detail::thread_data_base
{
    F& f;

    thread_data(boost::reference_wrapper<F> f_):
        f(f_)
    {}

    void run()
    {
        f();
    }
};

我看到,实际上,thread::thread_data 似乎被声明了两次。那里使用了哪些 C++ 功能?我怎样才能克服编译器的缺陷?

4

1 回答 1

1

第二个实例是模板类的部分特化,这是有效的 C++,不应导致重新定义错误。

过去,我在 Metrowerks 编译器中也遇到过此类功能的问题,更具体地说,当使用具有默认值的模板模板参数时,编译器永远不会编译它。我的解决方法很简单,不要提供默认值... (1)

如果我是你,我会尝试为你的特定类型添加一个完整的专业化,并希望编译器为那些使用一些不同的编译路径并让你通过这个......(这只是一个疯狂的猜测,我没有/这些天使用 Metrowerks 编译器)

typedef boost::function< void () > MyThreadFunction; // or whatever you need

template <>
struct thread::thread_data<boost::reference_wrapper< MyThreadFunction > >:
    detail::thread_data_base
{
    ....
};

(1) 老实说,这是很多年前的事了,我认为当时没有任何编译器完全编译模板。

于 2009-07-10T11:40:23.227 回答