显式专用模板,静态与重复符号

Explicitly specializing template, static vs. duplicate symbols

本文关键字:符号 静态 专用      更新时间:2023-10-16

在我继承的一堆遗留代码中,单元测试是使用 Boost.Test 实现的。为了能够通过BOOST_CHECK_EQUAL()检查std::wstringicu::UnicodeString的相等性,原作者为equal_impl()实现了显式模板专用化:

// test_utils.hpp
#include <boost/test/unit_test.hpp>
#include <unicode/unistr.h>
namespace boost
{
namespace test_tools
{
namespace tt_detail
{
template<>
static
boost::test_tools::predicate_result equal_impl( const std::wstring & wleft, const icu::UnicodeString & uright )
{
    const icu::UnicodeString uleft = w2u( wleft );
    return uleft == uright;
}
template<>
static
boost::test_tools::predicate_result equal_impl( const icu::UnicodeString & uleft, std::wstring & wright )
{
    const icu::UnicodeString uright = w2u( wright );
    return uleft == uright;
}
}
}
}

现在,此构造将模板专用化标记为 static 。我知道旧的 GCC 版本接受了这一点,但今天的版本(4.3 后)拒绝它:

error: explicit template specialization cannot have a storage class

但是,如果我删除static,我会在链接时multiple definition。而且我不能将所有内容都放在匿名命名空间中,可以吗,因为我必须在boost::test_tools::tt_detail中专门化模板?

我不知道如何解决这个问题(没有将所有测试完全重构为使用自定义谓词而不是BOOST_CHECK_EQUAL())...?

请注意,不幸的是,C++11 目前不是一个选项,因为并非所有目标平台都有适当的编译器支持。

static替换为inline就可以了。