8

我想重命名一个模板类。为了使用户的过渡更容易,我想将旧类保留为另一个版本,并使用 GCC / Clang 的扩展将其标记为已弃用(不推荐使用属性)。为了避免保留已弃用类的精确副本,使用模板别名会很方便。不幸的是,它似乎不起作用。这是我在 Clang 3.3、GCC 4.7 和 GCC 4.8 中尝试过的:

template <class blabla>
struct NewClassName
{
    // ...
};

template <class blabla> using OldClassName [[deprecated]]
  = NewClassName<blabla>;

我错过了什么还是编译器不支持它?是否有其他想法可以在不复制整个班级的情况下获得弃用警告?

4

1 回答 1

7

GCC 确实支持从 4.9 版开始弃用模板别名(从 4.7 开始带有__attribute__(deprecated))。这是一个比较 typedef 和模板别名的测试用例:

template <class T>
struct NewClassName
{
    // ...
};

template <class T> using OldClassNameUsing [[deprecated]]
  = NewClassName<T>;

typedef NewClassName<int> OldClassNameTypedef [[deprecated]];

int main()
{
  OldClassNameUsing<int> objectUsing;
  OldClassNameTypedef objectTypedef;

  return 0;
}

它对我不起作用的原因是我没有创建 OldClassNameUsing 的对象,而是访问了像 OldClassNameUsing::myFunction() 这样的静态成员。除非函数本身已被弃用,否则这永远不会触发弃用警告。

Clang 尚不支持弃用模板别名 - 使用版本 13 测试。相应的功能请求是 http://llvm.org/bugs/show_bug.cgi?id=17862 https://github.com/llvm/llvm-project /问题/18236

于 2013-11-12T06:44:45.570 回答