编译加密库时出现问题

时间:2013-05-20 19:17:18

标签: c++ c++11 g++

编译加密库时遇到错误

crypto/ope.cpp: In member function ‘NTL::ZZ OPE::encrypt(const NTL::ZZ&, int)’:
crypto/ope.cpp:80: error: expected primary-expression before ‘[’ token
crypto/ope.cpp:80: error: expected primary-expression before ‘const’
crypto/ope.cpp:80: error: expected primary-expression before ‘const’
crypto/ope.cpp: In member function ‘NTL::ZZ OPE::decrypt(const NTL::ZZ&)’:
crypto/ope.cpp:110: error: expected primary-expression before ‘[’ token
crypto/ope.cpp:110: error: expected primary-expression before ‘const’
crypto/ope.cpp:110: error: expected primary-expression before ‘const’

代码段如下:

template<class CB> 
ope_domain_range
OPE::search(CB go_low)
{
    blockrng<AES> r(aesk);

    return lazy_sample(to_ZZ(0), to_ZZ(1) << pbits,
                       to_ZZ(0), to_ZZ(1) << cbits,
                       go_low, &r);
}

ZZ
OPE::encrypt(const ZZ &ptext, int offset)
{
    ope_domain_range dr =
        search([&ptext](const ZZ &d, const ZZ &) { return ptext < d; }); 

    blockrng<AES> aesrand(aesk);
    auto v = sha256::hash(StringFromZZ(ptext));
    v.resize(16);
    aesrand.set_ctr(v);

    ZZ nrange = dr.r_hi - dr.r_lo + 1;
    if (nrange < 4 || det)
        return dr.r_lo + aesrand.rand_zz_mod(nrange);

    ZZ nrquad = nrange / 4;
    static urandom urand;

    switch (offset) {
    case -1: 
        return dr.r_lo + urand.rand_zz_mod(nrquad);
    case 0:
        return dr.r_lo + nrquad + urand.rand_zz_mod(nrquad * 2); 
    case 1:
        return dr.r_lo + nrquad * 3 + urand.rand_zz_mod(nrquad);
    default:
        assert(0);
    }   
}

第80行的代码(第110行上的代码相似):

ope_domain_range dr =
        search([&ptext](const ZZ &d, const ZZ &) { return ptext < d; }); 

我不太熟悉新的C ++标准C ++ 11。这是新标准新推出的吗? 如果不是,那是什么意思? 如果是,我可以使用g ++版本4.4.7编译C ++ 11代码吗? (目前我用g ++ 4.4.7标记为-std = c ++ 0x来编译库。)

非常感谢。

1 个答案:

答案 0 :(得分:2)

有问题的代码是C ++ 11 lambda,“[]”所包含的部分是捕获器,它告诉编译器应该传入哪些变量和常量在lambda之外,以及如何传入。

在这种特殊情况下,lambda通过引用捕获ptext。

GCC's c++0x page for GCC 4.4的快速检查表明它没有实现lambdas。您必须升级到更新的编译器。