Captura de este puntero en lambda wrapper alrededor de la función recursiva

Tengo una plantilla de claseWrap<T> con una función miembro recursivatest(int) que quiero pasar a un algoritmo STL con un lambda (std::accumulate en el código de abajo).

Si utilizo una lista de captura predeterminada de=, y hacer mi función meber recursivastatic, todo está bien y consigue el resultado que quiero.

Sin embargo, si lo convierto en una función miembro no estática, tanto Visual C ++ como gcc 4.7.2 se quejan de una unidad unificadathis-punto, a menos que yo califique mi llamada recursiva comothis->test().

#include <algorithm>
#include <iostream>
#include <vector>

template<typename T>
struct Wrap 
{
   static int test1(int depth)
   {
      std::vector<int> v = { 0, 1, 2, 3 };
      return depth == 0? 1 : std::accumulate(v.begin(), v.end(), int(0), [=](int sub, int const&) {
         return sub + test1(depth - 1);
      });   
   }

   int test2(int depth)
   {
      std::vector<int> v = { 0, 1, 2, 3 };
      return depth == 0? 1 : std::accumulate(v.begin(), v.end(), int(0), [=](int sub, int const&) {
         return sub + /*this->*/test2(depth - 1);
      });   
   }   
};

int main()
{
   std::cout << Wrap<int>::test1(0) << "\n"; // 1
   std::cout << Wrap<int>::test1(1) << "\n"; // 4
   std::cout << Wrap<int>::test1(2) << "\n"; // 16

   Wrap<int> w;
   std::cout << w.test2(0) << "\n"; // 1
   std::cout << w.test2(1) << "\n"; // 4
   std::cout << w.test2(2) << "\n"; // 16
}

Salida enLiveWorkSpace:

source.cpp: In instantiation of 'int Wrap<T>::test2(int) [with T = int]':   
source.cpp:32:26:   required from here 
source.cpp:19:74: error: missing initializer for member 'Wrap<T>::test2(int) [with T = int]::<lambda(int, const int&)>::__this' [-Werror=missing-field-initializers]

Sin comentar el/*this->/* pieza, da el mismo resultado que para la función miembro estática.

¿Por qué necesito calificar mi llamada recursiva conthis->?

Respuestas a la pregunta(1)

Su respuesta a la pregunta