如何在LLVM位向量上操作?

时间:2019-03-04 06:01:22

标签: c++ llvm llvm-clang

(很抱歉,我很抱歉,我不太熟悉C ++)

我有

#include <llvm/ADT/BitVector.h>

查看定义文件,它定义了

// Intersection, union, disjoint union
bitVector &operator&=(const BitVector RHS) { ... }

我想对两个位向量进行并集;看来这是路口的定义,所以我猜路口会像这样:

bitVector1 &= bitVector2;

这是正确的吗?进一步,它声明,不加评论,

bitVector &operator|=(const bitVector &RHS) { ... }

假设这是联合运算符是否正确? (位操作为| =)

感谢您的帮助!

1 个答案:

答案 0 :(得分:4)

&=对LHS和RHS BitVector的各个元素执行逻辑与  操作数并将结果存储在LHS操作数中。

|=对LHS和RHS BitVector的各个元素执行逻辑或  操作数并将结果存储在LHS操作数中。

一个最小的例子:

#include <iostream>
#include <llvm/ADT/BitVector.h>

llvm::BitVector  bitVector1(10, true);
llvm::BitVector  bitVector2(10, false);
llvm::BitVector  bitVector3(10, true);

int main()
{
    for(int i = 0; i < bitVector1.size(); i++)
        std::cout << bitVector1[i] << ' ';
    std::cout << '\n';        

    bitVector2[4] = true; //5th element set to true

    bitVector1 &= bitVector2;

    for(int i = 0; i < bitVector1.size(); i++)
        std::cout << bitVector1[i] << ' ';
    std::cout << '\n';


    bitVector1 |= bitVector3;


    for(int i = 0; i < bitVector1.size(); i++)
        std::cout << bitVector1[i] << ' ';
    std::cout << '\n';        

}

输出:

1 1 1 1 1 1 1 1 1 1 
0 0 0 0 1 0 0 0 0 0 
1 1 1 1 1 1 1 1 1 1 

Live Demo