views:

364

answers:

4

Hi,

Usually static members/objects of one class are the same for each instance of the class having the static member/object. Anyways what about if the static object is part of a template class and also depends on the template argument? For example, like this:

template<class T>
class A{
public:
  static myObject<T> obj;
}

If I would cast one object of A as int and another one as float, I guess there would be two obj, one for each type?

If I would create multiple objects of A as type int and multiple floats, would it still be two obj instances, since I am only using two different types?

+4  A: 

Static members are different for each diffrent template initialization. This is because each template initialization is a different class that is generated by the compiler the first time it encounters that specific initialization of the template.

The fact that static member variables are different is shown by this code:

#include <iostream>

template <class T> class Foo {
  public:
    static int bar;
};

template <class T>
int Foo<T>::bar;

int main(int argc, char* argv[]) {
  Foo<int>::bar = 1;
  Foo<char>::bar = 2;

  std::cout << Foo<int>::bar  << "," << Foo<char>::bar;
}

Which results in

1,2
Yacoby
okay thanks! that was quick and helped alot :)
"different same"? ;)
jamesdlin
Since the question is about static members, the example program would be clearer if it did not create any Foo<T> instances. Rather than assigning to and printing out bar1.s, you could use Foo<int>::s instead.
Gareth Stockwell
@jamesdlin Ug. Fixed. I shouldn't try to flip the logic around in a sentence and then not properly proof read.
Yacoby
@gareth Valid point and I blame the fact I hadn't had a coffee at that point. Fixed an simplified the code.
Yacoby
+2  A: 

There are as many static member variables as there are classes and this applies equally to templates. Each separate instantiation of a template class creates only one static member variable. The number of objects of those templated classes is irrelevant.

Peter Alexander
+2  A: 

A<int> and A<float> are two entirely different types, you cannot cast between them safely. Two instances of A<int> will share the same static myObject though.

villintehaspam
thanks, that was short but cleared up everything I needed to know :)
A: 

In C++ templates are actually copies of classes. I think in your example there would be one static instance per template instance.

Thirler
"C++ templates are actually copies of classes": that does not make sense. 0) there are also template functions and template member functions, 1) define "copy". I guess what you mean is that each class template instantiation represents a new class type.
phresnel
Yes unlike Java, C++ internally makes a copy of the class to with the template part filled in.
Thirler