= ord("\xFF")
Примерно раза в 2 быстрее, нежели:
2) [1 => $chr] = unpack('C', "\xFF")
Хотел тоже самое для int8 провернуть, считываю, например "ÿ", получается:
1) Для ord: 1111111111111111111111111111111111111111111111111111111111000011
2) Для unpack + 'c': 0000000000000000000000000000000000000000000000000000000011000011
Накинул маску ord($byte) | -0x100 (т.е. как раз эти самые первые биты в единицу). Всё ок. Но трабла в том, что этот байт в отрицательном диапазоне (в интервале [127...255], если бы мы считали как uint8). В случае положительного всё ломается.
Если добавить тернарник, вроде: $byte > 127 ? $byte | -0x100 : $byte, то всё работает. Причём примерно в 1.5 - 2 раза быстрее, нежели unpack, но есть подозрение, что можно и без тернарника скастовать как-то, тупо двигая байтики. Но что-то я не могу допедрить =\
Эм... Задача в том, что нужно просто прочитать байт как int8 и всё)
ord не читает без знаковые числа
Обсуждают сегодня