手写python字节缓冲区ByteBuffer

定义api

static ByteBuffer wrap(bytearray)
void put_int8(value)
byte get_int8()
void put_int16(value)
short get_int16()
void put_int32(value)
int get_int32()
void put_int64()
long get_int64()
void put_float64()
float get_float64()
void put(value)
boolean get(value)
void put(bytearray, offset, length)
void get(bytearray, offset, length)
bytearray array()
int readable_bytes()
int read_index()
int write_index()

byte 1字节 short 2字节 int 4字节 long 8字节 float 8字节 boolean 1字节

源码

#!/usr/bin/env python3
# -*- coding:utf-8 -*-
# @author jsbxyyx
# @since 1.0
import struct


class ByteBuffer(object):

    def __init__(self):
        self._array = bytearray(1024)
        self._write_index = 0
        self._read_index = 0

    @staticmethod
    def wrap(array):
        if not isinstance(array, bytearray):
            raise TypeError('Can wrap only to bytearray')
        bb = ByteBuffer()
        bb.put(array)
        return bb

    def put_int8(self, value):
        dst_offset = self._write_index
        self._write_index += 1
        struct.pack_into('!b', self._array, dst_offset, value)

    def get_int8(self):
        if self._read_index > self._write_index - 1:
            raise IndexError('Not enough data to get')
        src_offset = self._read_index
        self._read_index += 1
        return struct.unpack_from('!b', self._array, src_offset)[0]

    def put_int16(self, value):
        dst_offset = self._write_index
        self._write_index += 2
        struct.pack_into('!h', self._array, dst_offset, value)

    def get_int16(self):
        if self._read_index > self._write_index - 2:
            raise IndexError('Not enough data to get')
        src_offset = self._read_index
        self._read_index += 2
        return struct.unpack_from('!h', self._array, src_offset)[0]

    def put_int32(self, value):
        dst_offset = self._write_index
        self._write_index += 4
        struct.pack_into('!i', self._array, dst_offset, value)

    def get_int32(self):
        if self._read_index > self._write_index - 4:
            raise IndexError('Not enough data to get')
        src_offset = self._read_index
        self._read_index += 4
        return struct.unpack_from('!i', self._array, src_offset)[0]

    def put_int64(self, value):
        dst_offset = self._write_index
        self._write_index += 8
        struct.pack_into('!q', self._array, dst_offset, value)

    def get_int64(self):
        if self._read_index > self._write_index - 8:
            raise IndexError('Not enough data to get')

        src_offset = self._read_index
        self._read_index += 8
        return struct.unpack_from('!q', self._array, src_offset)[0]

    def put_float64(self, value):
        dst_offset = self._write_index
        self._write_index += 8
        struct.pack_into('!d', self._array, dst_offset, value)

    def get_float64(self):
        if self._read_index > self._write_index - 8:
            raise IndexError('Not enough data to get')

        src_offset = self._read_index
        self._read_index += 8
        return struct.unpack_from('!d', self._array, src_offset)[0]

    def put_bool(self, value):
        if value:
            self.put_int8(1)
        else:
            self.put_int8(0)

    def get_bool(self):
        if self.get_int8():
            return True
        else:
            return False

    def put(self, array, offset=0, length=None):
        if not isinstance(array, bytearray):
            raise TypeError('Can put only bytearray')

        array_len = len(array)

        if length is None:
            length = array_len - offset
        else:
            if not (0 <= length <= array_len - offset):
                raise ValueError('Length out of range')

        dst_offset = self._write_index
        self._write_index += length
        self._array[dst_offset:dst_offset + length] = array[offset:offset + length]

        return length

    def get(self, array, offset=0, length=None):
        if not isinstance(array, bytearray):
            raise TypeError('Can get only to bytearray')

        array_len = len(array)

        if not (0 <= offset <= array_len):
            raise ValueError('Offset out of range')

        if length is None:
            length = array_len - offset
        else:
            if not (0 <= length <= array_len - offset):
                raise ValueError('Length out of range')

        src_offset = self._read_index
        self._read_index += length
        array[offset:offset + length] = self._array[src_offset:src_offset + length]

        return length

    def array(self):
        return bytearray(self._array[0:self._write_index])

    def readable_bytes(self):
        return self._write_index - self._read_index

    def read_index(self):
        return self._read_index

    def write_index(self):
        return self._write_index

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值