开发者

How can I do 64-bit arithmetic in Perl?

I am a perl newbie,

Can I simply use 64-bit arithmetic in Perl?

For ex开发者_开发百科ample

$operand1 = 0xFFFFFFFFFFFF;   # 48 bit value
$operand2 = 0xFFFFFFFFFFFF;   # 48 bit value

$Result = $operand1 * $operand2;
  • I am basically looking for a replacement for the int64_t in perl.
  • Is there any way to mention, if the variable is signed or unsigned?


Yes, however you need to have Perl compiled with 64-bit support.


See bigint:

Transparent BigInteger support for Perl...

All operators (including basic math operations) except the range operator .. are overloaded. Integer constants are created as proper BigInts.

Floating point constants are truncated to integer. All parts and results of expressions are also truncated.

Unlike integer, this pragma creates integer constants that are only limited in their size by the available memory and CPU time...


Yes, Perl automatically handles large integer arithmetic for you. However, Perl does not offer a distinction between signed and unsigned types (there's no need, since there are not fixed bounds on large integer range).

The perlnumber manual page has more information about the different numeric formats supported by Perl.


Be aware, 64bit arithmetic in Perl is one, but what it is displayed by sprintf %d %u and %s, is second. Current perl version supports 64bits without problems, but sprintf %d format not, %b likewise .


use bigint will make Perl handle arbitrary size integers correctly without integer overflow.

Eg.:

use bigint;
print 1 << 256;

will print:

115792089237316195423570985008687907853269984665640564039457584007913129639936
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜