c2797 成员初始化器列表或非静态数据成员初始化器中的列表初始化未实现

c2797 List initialization inside member initializer list or non static data member initializer not implemented

我在 visual studio 2013 年尝试编译我的项目时遇到以下错误。

c2797:未实现成员初始化器列表或非静态数据成员初始化器中的列表初始化

这是抛出上述编译器错误的代码。

====sample.h====

enum class Process
{


  TUNNEL_IP_VERSION,  // Tunnel::IPVersion::Type
  PADDING_BYTE,
  IP_ADDRESS_FIT_ACTUAL_SIZE,
  IP_ADDRESS_FIT_IPv6_SIZE,
  PORT_NUMBER,
};

using ProcessingOrder = std::vector<Process>;

const ProcessingOrder m_ProcessingOrder =
{


  Process::TUNNEL_IP_VERSION,
  Process::PADDING_BYTE,
  Process::IP_ADDRESS_FIT_IPv6_SIZE,
  Process::PORT_NUMBER
};

虽然VS2013支持c++11的特性-初始化列表,为什么会出现上面的错误!?如何摆脱这种情况?我需要更改代码中的哪些内容才能解决此问题?

感谢您的回答。效果很好。 对于以下语句,我也有类似的情况。

m_Attribute{SSL_CTX_new(g_SSLChoice[version].m_pfSSLMethod()), 0, 0}
  {

其中, m_Attribute是,

struct{
         SSL_CTX* const m_pContext;
         Socket* m_pSocket;
         X509* m_pCertificate;
         }m_Attribute;

SSL_CTX_new,是ssl.have
中的标准定义 g_SSLChoice 是,

g_SSLChoice[CloudSSL::TLSv1_2 + 1] =
  {
    /* [SSLv23] = */ {&SSLv3_client_method, 0},
    /* [SSLv3] = */ {&SSLv23_client_method, SSL_OP_NO_SSLv2},
    /* [TLSv1] = */ {&TLSv1_client_method, SSL_OP_NO_SSLv3},
    /* [TLSv1_1] = */ {&TLSv1_1_client_method, SSL_OP_NO_TLSv1},
    /* [TLSv1_2] = */ {&TLSv1_2_client_method, SSL_OP_NO_TLSv1_1}
  };

其中,

class云SSL:publicUtil::Thread
  {

public: 枚举版本
        {
          // SSLv2, // 不支持
          SSLv23,
          SSLv3,
          TLSv1,
          TLSv1_1,
          TLSv1_2
        };

最后 m_pfSSLMethod 是, const SSL_METHOD* (*m_pfSSLMethod)();

Visual Studio 尚未实现此功能。可以找到解决方法 here

你可以直接使用

const ProcessingOrder m_ProcessingOrder = ProcessingOrder
{
  Process::TUNNEL_IP_VERSION,
  Process::PADDING_BYTE,
  Process::IP_ADDRESS_FIT_IPv6_SIZE,
  Process::PORT_NUMBER
};

对于你的第二个案例。

struct Attribute_t{
         SSL_CTX* const m_pContext;
         Socket* m_pSocket;
         X509* m_pCertificate;
         }m_Attribute;

然后

m_Attribute = Attribute_t{SSL_CTX_new(g_SSLChoice[version].m_pfSSLMethod()),
0, 0}