PHP进制的转换问题

先学习几个单词:

dec: 十进制

bin:进制

oct:八进制

hex:十六进制

  • 十进制转二进制decbin(),除2取余倒着写

$v1 = decbin(123); //注意:参数必须是10进制数字,转换后的结果必然是二进制字符串。

PHP进制的转换问题

我们也可以通过手工的方式来完成10进制转2进制的完整过程。

基本做法是:将10进制数字除以2,并取得余数,如果除得的商不为0,则继续除以2,并继续去的余数,直到商为0。然后将所有取得的余数,按“倒序写出”,就是对应的2进制数字:

PHP进制的转换问题

  • 十进制转八进制decoct(),除8取余倒着写

使用php系统函数:

$r1 =  decoct(十进制数字);     //结果是一个8进制数字字符串。

PHP进制的转换问题

我们也可以通过手工的方式来完成10进制转8进制的完整过程。

基本做法是:将10进制数字除以8,并取得余数,如果除得的商不为0,则继续除以8,并继续去的余数,直到商为0。然后将所有取得的余数,按“倒序写出”,就是对应的8进制数字:

PHP进制的转换问题

  • 十进制转十六进制dechex(),除16取余倒着写

16进制的数字包括如下(从0开始):

0     1     2     3     4     5     6     7     8     9     A     B     C     D     E     F

对应10进制其实是:

0     1     2     3     4     5     6     7     8     9     10    11    12    13    14    15

系统函是:dechex(十进制数字), 结果是16进制数字字符串。

PHP进制的转换问题

手工运算:

基本做法是:将10进制数字除以16,并取得余数,如果除得的商不为0,则继续除以16,并继续去的余数,直到商为0。然后将所有取得的余数,按“倒序写出”,就是对应的16进制数字:

PHP进制的转换问题

  • 二进制转十进制bindec(),每位数值乘以2的权值然后相加

先理解一个“权值”概念:

就是某位数字上的该数字所代表的数的大小。比如:

10进制数字1234,其代表:1*10 3+ 2*102 + 3*101  + 4*100  =  1000+ 200 + 30 + 4;

这里,10 3, 102 ,101 ,等等,就称为权值。

二进制转10进制,就是将每位数值乘以对应位上的权值,然后相加得到的结果。

用系统函数是:

$v1  =  bindec(“二进制数字字符串”) ;//得到的结果是10进制数字

结果:

PHP进制的转换问题

手工转换:

二进制数字的权值,从右到左,分别是:

20, 21, 22, 23, 24, 25,.....

即分别是(10进制大小):

1, 2,  4,  8,  16,32

手工计算:

1010110

=1*26 + 0*XX  + 1*24 + 0*XX  + 1*22 + 1*21 + 0 //说明,其中XX表示无所谓的数字值

=64 + 0 + 16 + 0 + 4 + 2 + 0

=86

  • 八进制转十进制octdec() ,每位数值乘以8的权值然后相加

用系统函数是:

$v1  =  octdec(“8进制数字字符串”) ;//得到的结果是10进制数字

PHP进制的转换问题

结果:

手工算法统2进制转换为10进制,略。

  • 十六进制转十进制hexdec() ,每位数值乘以16的权值然后相加

用系统函数是:

$v1  =  hexdec(“16进制数字字符串”) ;//得到的结果是10进制数字

结果:

PHP进制的转换问题

  • 注意:十进制转为其他进制结果是字符串,其他进制转为十进制要求给定数据是字符串形式

思考:

$v1 = bindec(123);//理解过程:bindec(“123”) =>bindec(“1”)=>1

$v2 = bindec(0123);//理解:0123是8进制数字,其10进制值为:83,再当作二进制字符串就是“83”,结果就只能是0

$v3 = bindec(“0123”);//理解:因为直接就是字符串了,就当二进制字符串用,结果是1

$v4 = octdec(0123);      //理解:0123是8进制数字,其10进制值为:83,再当作8进制字符串就是“83”,但8进制中没有“8”这个数字,就只识别出一个“3”这个数字

以下代码测试:

PHP进制的转换问题

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/4700.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚的头像重蔚管理团队
上一篇 2018年3月14日 12:44
下一篇 2018年3月14日 16:19

相关推荐

  • 重蔚php学习第二十七天——php可变变量,匿名函数

    运算符:赋值运算符,算术运算符,错误抑制符,比较运算符,逻辑运算符,三元运算符,位运算符,连接运算符,自操作运算符(在项目计算当中,非常不建议使用多个自操作一起运算) 源码反码补码 整数的原码反码和补…

    2017年5月5日 PHP自学教程
    0379
  • Redis和PHP的速度对比。

    Redis是一款高性能的缓存数据库,被广泛地用于提升Web应用程序的性能。它以其高速读取和写入数据的能力,以及良好的可扩展性而受到Web开发人员的青睐。而PHP是一门流行的Web编程语言,以其易学易用、开发效率高等特…

    2023年5月21日
    02
  • PHP中的服务器负载均衡。

    在当前网络高并发的环境中,服务器的负载均衡变得越来越重要。负载均衡通过分配工作负载到多个服务器上,可以加强服务器容量和性能,防止单个服务器在高流量和请求时崩溃,从而提高网站的可靠性,可扩展性和可用性…

    2023年5月28日
    02
  • 商城开发中如何利用PHP实现推荐算法

    随着电子商务行业的飞速发展,商城的推荐算法也变得越来越重要。推荐算法可以为用户提供个性化的推荐服务,从而提高用户的购买率,并为商城带来更多的收益。在商城开发中,PHP是一种常用的编程语言,而如何利用PHP…

    2023年5月19日
    015
  • 我来说说如何使用PHP代码实现QQ代码。

    PHP代码实现QQ代码:通过调用腾讯QQ互联API,获取access_token和openid,然后生成QQ二维码。 什么是QQ代码? QQ代码,又称为QQ透明皮肤,是一种基于腾讯QQ聊天软件的自定义皮肤,通过编写特定的HTML、CSS和JavaScript…

    2024年7月7日
    00
  • PHP安全问题汇总

    1-XSS Cross-Site Scripting(跨站脚本攻击)简称 XSS,是一种代码注入攻击。攻击者通过在目标网站上注入恶意脚本,使之在用户的浏览器上运行。利用这些恶意脚本,攻击者可获取用户的敏感信息如 Cookie、SessionID …

    2022年6月20日
    0119
  • PHP实现邮件分组发送的方法。

    随着网络通讯的普及,电子邮件已经成为了人们日常生活中不可或缺的一部分。在现代的企业、机构和个人中,发送邮件已经成为了必备的工作环节之一。在许多应用场景中,我们需要向一组人或多组人发送邮件,这时候就需…

    2023年5月28日
    01
  • PHP与数据挖掘的集成。

    目前,数据挖掘在各行各业中都扮演着非常重要的角色,同时PHP作为一种流行的编程语言,在开发Web应用方面具有广泛的应用。因此,将PHP与数据挖掘集成起来,可以为开发人员提供更强大的功能和更高效的方法。本文将介…

    2023年5月21日
    05

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息