$buff = pack('nn',0xabcd,0x01);
$pos = strpos($buff,0x01);
echo $pos;
返回结果是3,0xabcd是两个字节,那么0x01的位置按照0,1,2顺序,不应该是2吗?
$buff = pack('nn',0xabcd,0x01);
$pos = strpos($buff,0x01);
echo $pos;
返回结果是3,0xabcd是两个字节,那么0x01的位置按照0,1,2顺序,不应该是2吗?
1 回答4.1k 阅读✓ 已解决
3 回答1.9k 阅读✓ 已解决
2 回答2.2k 阅读✓ 已解决
2 回答2.2k 阅读
1 回答1.4k 阅读✓ 已解决
798 阅读
649 阅读
pack参数n的意思是 16bit unsigned short, big endian(即网络字节序)
所以pack出来的结果是4个字节(16 + 16 bit), ord看$buff[0],[1],[2],[3]的话分别是171, 205, 0 ,1
0x01按照ushort的话是0x0001
strpos的offset也应该是3
171 = 16 * 10 (a) + 11 (b)
205 = 16 * 12 (c) + 13 (d)
顺便: 如果pack用S参数的话, unsigned short (always 16 bit, machine byte order), 咱们常用的X86 CPU都是little endian, 所以
$buff的结果就应该是 205, 171, 1, 0
这个时候offset就是2了
核心是字节序问题