将字符串视为二进制,并在perl中进行二进制操作

时间:2012-04-26 23:05:31

标签: string perl binary bit-manipulation

假设我在perl中有两个字符串

$a = "10001";
$b = "10101";

我需要找到这两个字符串的按位xor,即

$a XOR $b = "00100";

我应该如何在perl中执行此操作?

6 个答案:

答案 0 :(得分:4)

xor two numbers

my $n1 = 0b10001;
my $n2 = 0b10101;
my $n = $n1 ^ $n2;
say sprintf '%05b', $n;

要xor两个数字(从字符串形式开始):

my $n1 = '10001';
my $n2 = '10101';
my $len = max map length, $n1, $n2;
my $n = oct("0b$n1") ^ oct("0b$n2");
say sprintf '%0*b', $len, $n;

xor two strings :(任何长度,只要两个字符串相同):

my $n1 = '10001';
my $n2 = '10101';
my $n = ($n1 ^ $n2) | ("\x30" x length($n1));
say $n;

要xor两个字符串:(任何长度):

my $n1 = '010001';
my $n2 = '10101';
my $len = max map length, $n1, $n2;
$n1 = substr((" " x $len).$n1, -$len);
$n2 = substr((" " x $len).$n2, -$len);
my $n = ($n1 ^ $n2) | ("\x30" x $len);
say $n;

答案 1 :(得分:3)

使用oct

  

如果EXPR以0b开始,则将其解释为二进制字符串。

#!/usr/bin/env perl

my ($x, $y) = map oct "0b$_", qw(10001 10101);
printf "%08b\n", $x ^ $y;

答案 2 :(得分:2)

如果您自己声明信息,可以使用一些文字:

my $first = 0b10001;
my $second = 0b10101;

my $xored = $first ^ $second;

if ($xored == 0b00100)
{
    print "Good!";
}

也适用于数字和十六进制:

my $first = 21;    # or 0b10101 or 0x15
my $second = 0x11; # or 0b10001 or 17

my $xored = $first ^ $second;

if ($xored == 0b00100) # or == 4,  or == 0x04 
{
    print "Good!";
}

另外,您还应避免使用$a$b,因为它们对sort函数具有特殊含义。

答案 3 :(得分:1)

使用此子程序:

sub bin2dec {
    return unpack("N", pack("B32", substr("0" x 32 . shift, -32)));
}

它会将字符串转换为整数,你可以在它们上使用按位XOR ^,然后测试它是否等于4。

答案 4 :(得分:0)

您可以编写一些执行一位操作的函数:

sub xor
{
   my $p = shift;
   my $q = shift;

   return ( $p eq $q ) "0" : "1";
}

然后你可以成功地为每对字符(每个连续的位)调用它。

for (my $index = 0; $index < inputLength; $index++)
{
     $result = $result . xor ( substr ($a, $index, 1), substr ($b, $index, 1) );
}

其中inputLength$a$b的长度。 这是一种方法。希望这有帮助!

答案 5 :(得分:0)

至于$ a和$ b有固定长度,比如说5:

 $a = '00011';
 $b = '00110';
 $xor = ($a ^ $b) | '00000';