处理 STL 容器时的 C++ 类专门化

标签 c++ templates stl vector specialization

我想要一个函数返回基本类型对象的大小(以字节为单位)。我还希望它返回 STL 容器的总大小(以字节为单位)。 (我知道这不一定是内存中对象的大小,没关系)。

为此,我编码了 memorysize带有 bytes 的命名空间函数使得 memorysize::bytes(double x) = 8 (在大多数编译器上)。

我已将其专门用于正确处理 std::vector<double>类型,但我不想为 std::vector<ANYTHING> 形式的每个类编写不同的函数,那么如何更改模板才能正确处理这种情况?

这是工作代码:

#include <iostream>
#include <vector>

// return the size of bytes of an object (sort of...)
namespace memorysize
{

  /// general object
  template <class T>
  size_t bytes(const T & object)
  {
    return sizeof(T);
  }

  /// specialization for a vector of doubles
  template <>
  size_t bytes<std::vector<double> >(const std::vector<double> & object)
  {
    return sizeof(std::vector<double>) + object.capacity() * bytes(object[0]);
  }

  /// specialization for a vector of anything???

}


int main(int argc, char ** argv)
{

  // make sure it works for general objects
  double x = 1.;
  std::cout << "double x\n";
  std::cout << "bytes(x) = " << memorysize::bytes(x) << "\n\n";

  int y = 1;
  std::cout << "int y\n";
  std::cout << "bytes(y) = " << memorysize::bytes(y) << "\n\n";

  // make sure it works for vectors of doubles
  std::vector<double> doubleVec(10, 1.);
  std::cout << "std::vector<double> doubleVec(10, 1.)\n";
  std::cout << "bytes(doubleVec) = " << memorysize::bytes(doubleVec) << "\n\n";

  // would like a new definition to make this work as expected
  std::vector<int> intVec(10, 1);
  std::cout << "std::vector<int> intVec(10, 1)\n";
  std::cout << "bytes(intVec) = " << memorysize::bytes(intVec) << "\n\n";

  return 0;
}

如何更改模板规范以允许更通用的 std::vector<ANYTHING>案例?

谢谢!

最佳答案

相应地修改您的代码:

/// specialization for a vector of anything
template < typename Anything >
size_t bytes(const std::vector< Anything > & object)
{
  return sizeof(std::vector< Anything >) + object.capacity() * bytes( object[0] );
}

请注意,现在如果使用空的 vector 调用bytes,则会遇到问题。

编辑:从头开始。如果我正确地记得你之前的问题,那么如果你得到一个字符串 vector ,那么你会想要考虑每个字符串所占用的大小。所以你应该这样做

/// specialization for a vector of anything
template < typename Anything >
size_t bytes(const std::vector< Anything > & object)
{
  size_t result = sizeof(std::vector< Anything >);

  foreach elem in object
       result += bytes( elem );

  result += ( object.capacity() - object.size() ) * sizeof( Anything ).

  return result;
}

关于处理 STL 容器时的 C++ 类专门化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7458327/

相关文章:

调用模板函数时进行 C++ 模板推导

c++ - 为您自己的 STL 容器 C++ 推送 _back

c++ - 如何访问(例如,cout)多维 STL vector 中迭代器的当前值 (C++)

c++ - 为什么有些共享库以 d.so 而不是 .so 结尾?

C++ getline() 函数引入整个文件

c++ - 这个模板元程序中的 int*** 是如何工作的?

c++ - Eclipse[HELIOS] CDT : Autocomplete, STL 不能与 Eclipse 一起工作..帮助!

c++ - 在 std::pair 上使用 lambda 理解 std::find_if()

c++ - 模板参数的模板类型推导

django - 如何将上下文传递给模板而不在所有 View 中实际指定它?