Negative 64bit Decimal Number to Binary in php

后端 未结 1 1242
太阳男子
太阳男子 2021-01-25 07:38

I am trying to convert a decimal number for example

-268427136

to binary and vice versa.

If I try with windows Calc, binary

1条回答
  •  爱一瞬间的悲伤
    2021-01-25 07:46

    Your PHP is probably compiled for 32bit systems resulting in integer overflow and number being represented in 32bit. Ensure that your PHP is compiled for 64bit.

    You can check that with

    this should return 8. On my PHP the following works as PHP_INT_SIZE is 8:

    php > echo(decbin(-268427136));
    1111111111111111111111111111111111110000000000000010000010000000
    

    Background

    PHP uses the C language type long to represent integers internally (PHP is written in C). These are platform dependent. On 64bit system usually these are 64bit long. On Windows sometimes applications such as PHP are compiled for 32bit, despite the system supporting 64bit, resulting in long being 32bit or 4byte. Thus you get an overflow which results in a 32bit long number. In your case: 11110000000000000010000010000000

    bindec and 64bit numbers

    According to the PHP manual, bindec returns a number. As your number is 64bit, PHP interprets it as a float. It calculates the cutoff for using integer or float without the sign. See 2.

    php > var_dump(bindec('1111111111111111111111111111111111110000000000000010000010000000'));
    float(1.8446744073441E+19)
    

    This can be prevented by explicitly casting to int.

    php > var_dump((int)bindec('1111111111111111111111111111111111110000000000000010000010000000'));
    int(-268427264)
    

    0 讨论(0)
提交回复
热议问题