douqiandai4327 2013-02-07 22:32
浏览 127
已采纳

这是如何工作的:chr(($ number >> 6)+192).chr(($ number&63)+128);

Can you please explain how this line of code is equivalent to the next code:

<?php
$string = chr( ( $number >> 6 ) + 192 ).chr( ( $number & 63 ) + 128 );
?>

Its equivalent to :

if ( $number >=128 && $number <=2047 ){

   $byte1 = 192 + (int)($number / 64); //= 192 + ( $number >> 6 )
   $byte2 = 128 + ($number % 64);      //= 128 + ( $number & 63 )
   $utf = chr($byte1).chr($byte2);
 }

for example entering number 1989 both produces ߅

These codes are used for converting UNICODE Entities back to original UTF-8 characters.

  • 写回答

3条回答 默认 最新

  • dovhpmnm31216 2013-02-07 22:40
    关注

    The code on top uses binary operators. >> is right shift operator. It shifts the bit in the number to the right (towards more significant bits).

    So 11110000 >> 2 = 00111100

    It's equivalent to division by powers of 2 $number >> $n is the same as $number / pow(2,$n).

    The & is the "bitwise and" operator. It compares respective bits on both numbers, and sets in result those, that are 1 in both numbers.

    11110000 & 01010101 = 01010000

    By and'ing $number with 63 (001111111) you get the remainder of dividing $number by 64 (aka the modulus), which is written $number % 64.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 vue3页面el-table页面数据过多
  • ¥100 vue3中融入gRPC-web
  • ¥15 kali环境运行volatility分析android内存文件,缺profile
  • ¥15 写uniapp时遇到的问题
  • ¥15 vs 2008 安装遇到问题
  • ¥15 matlab有限元法求解梁带有若干弹簧质量系统的固有频率
  • ¥15 找一个网络防御专家,外包的
  • ¥100 能不能让两张不同的图片md5值一样,(有尝)
  • ¥15 informer代码训练自己的数据集,改参数怎么改
  • ¥15 请看一下,学校实验要求,我需要具体代码