标签:import abi func uid form pow document like ast
http://www.exploringbinary.com/base-conversion-in-php-using-built-in-functions/
http://www.binaryconvert.com/convert_float.html?decimal=054046056050049051
https://www.codeproject.com/Tips/387989/Convert-Binary-Single-Precision-Value-to-Float-in
function FloatToIEEE(f)
{
var buf = new ArrayBuffer(4);
(new Float32Array(buf))[0] = f;
return (new Uint32Array(buf))[0];
}
Unfortunately, this doesn‘t work with doubles and in old browsers
function DoubleToIEEE(f)
{
var buf = new ArrayBuffer(8);
(new Float64Array(buf))[0] = f;
return [ (new Uint32Array(buf))[0] ,(new Uint32Array(buf))[1] ];
}
-------------------------------------------------------------
The PHP programming language has many built-in functions for converting numbers from one base to another. In fact, it has so many functions that it can be hard to know which to use. Some functions have similar capabilities, and some work with parameters of different types. We’ll sort through the differences in this article, and explain the proper context in which to use each function.
As a guide to our discussion, our mission will be to write programs that take, as input, an integer in a given base, and produce, as output, the equivalent of that integer in another base. Both the input and output will be strings — sequences of characters with encodings like ASCII or EBCDIC. That is the form numbers take when read in from and written out to a user. Contrast this with numbers that can be operated on arithmetically inside a computer, numbers represented with binary integers or floating-point binary. I call numbers in that form numeric binary.
Why the distinction between string and numeric binary? Because both types are used in PHP’s conversion functions. Knowing which parameters are which type is key to using the functions properly.
PHP has built-in functions that can convert, or help convert, integers between string representations in various number bases. We will use them to convert between decimal (base 10), binary (base 2), hexadecimal (base 16), and octal (base 8). These are number bases that anyone versed in binary should know.
There’s an important point I need to make before continuing. In PHP, and just about anywhere else, functions described as converting to or from decimal really convert to or from numeric binary! If you take only one thing from this article, let that be it.
Here is a summary of the PHP conversion functions used in this article, with a description of how they’re used, and the maximum integer they can safely convert:
Function | Type of Conversion | Max Integer |
---|---|---|
bindec() | Binary string to numeric binary | 253 |
hexdec() | Hex string to numeric binary | 253 |
octdec() | Octal string to numeric binary | 253 |
intval() | Base 2 to 36 string to numeric binary | 231 – 1 |
sscanf() | Decimal, hex, or octal string to numeric binary | 231 – 1 |
decbin() | Numeric binary to binary string | 232 – 1 |
dechex() | Numeric binary to hex string | 232 – 1 |
decoct() | Numeric binary to octal string | 232 – 1 |
strval() | Numeric binary to decimal string | Between 239 and 240 |
sprintf() | Numeric binary to decimal, binary, hex, or octal string | 253 |
base_convert() | Base 2 to 36 string to base 2 to 36 string | 253 ? |
(? In the base_convert() documentation, there is this warning: “base_convert() may lose precision on large numbers due to properties related to the internal ‘double’ or ‘float’ type used.” If that leaves you wanting, it did me too.)
In the following sections, I give examples of conversions between specific base pairs. Look for the specific conversion in which you’re interested.
In the code, I use separate variables for the input string, the intermediate numeric binary value, and the output string. The separate string variables represent the I/O of a program, keeping the code independent of any particular I/O mechanism (HTML form I/O, echo, printf, etc.). The separate variables also make clearer which parameters are which type.
The examples which use intval and sscanf limit the maximum integer that can be converted — to 231 – 1. This is the case, for example, in the code that converts from decimal to binary, even though decbin supports integers up to 232 – 1. A similar thing happens when composing the `*dec’ and `dec*’ functions. For example, hexdec followed by decbin is limited to 232 – 1 by decbin.
The code does not label input and output strings with their base (for example, with prefixes like 0b, 0x, or 0o). The base is implied with context.
Here are three ways to convert a decimal string to a binary string using built-in functions:
<?php $decString = "42"; $binNumeric = intval($decString); $binString = decbin($binNumeric); // = "101010" ?>
<?php $decString = "32"; sscanf($decString,"%d",&$binNumeric); $binString = sprintf ("%b",$binNumeric); // = "100000" ?>
Note: support of the %b format specifier is nonstandard.
<?php $decString = "26"; $binString = base_convert($decString,10,2); // = "11010" ?>
Here are three ways to convert a binary string to a decimal string using built-in functions:
<?php $binString = "11011110"; $binNumeric = bindec($binString); $decString = sprintf("%.0f",$binNumeric); // = "222" ?>
<?php $binString = "10100"; $binNumeric = intval($binString,2); $decString = strval($binNumeric); // = "20" ?>
<?php $binString = "111000111001"; $decString = base_convert($binString,2,10); // = "3641" ?>
Here are three ways to convert a decimal string to a hexadecimal string using built-in functions:
<?php $decString = "42"; $binNumeric = intval($decString); $hexString = dechex($binNumeric); // = "2a" ?>
<?php $decString = "112"; sscanf($decString,"%d",&$binNumeric); $hexString = sprintf ("%x",$binNumeric); // = "70" ?>
<?php $decString = "25"; $hexString = base_convert($decString,10,16); // = "19" ?>
Here are four ways to convert a hexadecimal string to a decimal string using built-in functions:
<?php $hexString = "de"; $binNumeric = hexdec($hexString); $decString = sprintf("%.0f",$binNumeric); // = "222" ?>
<?php $hexString = "14"; $binNumeric = intval($hexString,16); $decString = strval($binNumeric); // = "20" ?>
<?php $hexString = "27"; sscanf($hexString,"%x",&$binNumeric); $decString = strval($binNumeric); // = "39" ?>
<?php $hexString = "25"; $decString = base_convert($hexString,16,10); // = "37" ?>
Here are three ways to convert a decimal string to an octal string using built-in functions:
<?php $decString = "42"; $binNumeric = intval($decString); $octString = decoct($binNumeric); // = "52" ?>
<?php $decString = "9"; sscanf($decString,"%d",&$binNumeric); $octString = sprintf ("%o",$binNumeric); // = "11" ?>
<?php $decString = "25"; $octString = base_convert($decString,10,8); // = "31" ?>
Here are four ways to convert an octal string to a decimal string using built-in functions:
<?php $octString = "77"; $binNumeric = octdec($octString); $decString = sprintf("%.0f",$binNumeric); // = "63" ?>
<?php $octString = "14"; $binNumeric = intval($octString ,8); $decString = strval($binNumeric); // = "12" ?>
<?php $octString = "14"; sscanf($octString ,"%o",&$binNumeric); $decString = strval($binNumeric); // = "12" ?>
<?php $octString = "61"; $decString = base_convert($octString,8,10); // = "49" ?>
You can use the functions above to convert between bases 2, 8, and 16 without going through decimal strings. One approach is to use base_convert; another is to compose the `*dec’ and `dec*’ functions.
Here are two ways to convert a hexadecimal string to a binary string using built-in functions:
<?php $hexString = "1f"; $binNumeric = hexdec($hexString); $binString = decbin($binNumeric); // = "11111" ?>
<?php $hexString = "ff"; $binString = base_convert($hexString,16,2); // = "11111111" ?>
Here are two ways to convert a binary string to a hexadecimal string using built-in functions:
<?php $binString = "10011"; $binNumeric = bindec($binString); $hexString = dechex($binNumeric); // = "13" ?>
<?php $binString = "1111"; $hexString = base_convert($binString,2,16); // = "f" ?>
Here are two ways to convert an octal string to a binary string using built-in functions:
<?php $octString = "77"; $binNumeric = octdec($octString); $binString = decbin($binNumeric); // = "111111" ?>
<?php $octString = "71"; $binString = base_convert($octString,8,2); // = "111001" ?>
Here are two ways to convert a binary string to an octal string using built-in functions:
<?php $binString = "1010"; $binNumeric = bindec($binString); $octString = decoct($binNumeric); // = "12" ?>
<?php $binString = "11011"; $octString = base_convert($binString,2,8); // = "33" ?>
Here are two ways to convert an octal string to a hexadecimal string using built-in functions:
<?php $octString = "77"; $binNumeric = octdec($octString); $hexString = dechex($binNumeric); // = "3f" ?>
<?php $octString = "123"; $hexString = base_convert($octString,8,16); // = "53" ?>
Here are two ways to convert a hexadecimal string to an octal string using built-in functions:
<?php $hexString = "7d8"; $binNumeric = hexdec($hexString); $octString = decoct($binNumeric); // = "3730" ?>
<?php $hexString = "f0"; $octString = base_convert($hexString,16,8); // = "360" ?>
Base Conversion In PHP and javascript
标签:import abi func uid form pow document like ast
原文地址:http://www.cnblogs.com/oxspirt/p/6930125.html