1
0
mirror of https://github.com/fumiama/go-base16384.git synced 2026-06-12 14:10:32 +08:00

优化代码结构

This commit is contained in:
源文雨
2023-04-19 15:33:33 +08:00
parent e8419f8b75
commit d548cdd86f
4 changed files with 16 additions and 31 deletions

View File

@@ -44,7 +44,7 @@ func Encode(b []byte) (encd []byte) {
return return
} }
func EncodeTo(b, encd []byte) error { func EncodeTo(b, encd []byte) (int, error) {
outlen := len(b) / 7 * 8 outlen := len(b) / 7 * 8
offset := len(b) % 7 offset := len(b) % 7
switch offset { //算上偏移标志字符占用的2字节 switch offset { //算上偏移标志字符占用的2字节
@@ -60,10 +60,10 @@ func EncodeTo(b, encd []byte) error {
outlen += 10 outlen += 10
} }
if len(encd) < outlen { if len(encd) < outlen {
return errors.New("encd too small") return 0, errors.New("encd too small")
} }
encode(offset, outlen, b, encd) encode(offset, outlen, b, encd)
return nil return outlen, nil
} }
//go:nosplit //go:nosplit
@@ -111,7 +111,7 @@ func Decode(b []byte) (decd []byte) {
} }
//go:nosplit //go:nosplit
func DecodeTo(b []byte, decd []byte) error { func DecodeTo(b []byte, decd []byte) (int, error) {
outlen := len(b) outlen := len(b)
offset := 0 offset := 0
if b[len(b)-2] == '=' { if b[len(b)-2] == '=' {
@@ -131,8 +131,8 @@ func DecodeTo(b []byte, decd []byte) error {
} }
outlen = outlen/8*7 + offset outlen = outlen/8*7 + offset
if len(decd) < outlen { if len(decd) < outlen {
return errors.New("decd too small") return 0, errors.New("decd too small")
} }
decode(offset, outlen, b, decd) decode(offset, outlen, b, decd)
return nil return outlen, nil
} }

View File

@@ -121,7 +121,7 @@ func benchEncode(b *testing.B, data []byte) {
b.SetBytes(int64(len(data))) b.SetBytes(int64(len(data)))
b.ResetTimer() b.ResetTimer()
for i := 0; i < b.N; i++ { for i := 0; i < b.N; i++ {
_ = EncodeTo(data, buf) _, _ = EncodeTo(data, buf)
} }
} }
@@ -131,14 +131,14 @@ func benchDecode(b *testing.B, data []byte) {
panic(err) panic(err)
} }
buf := make([]byte, EncodeLen(len(data))) buf := make([]byte, EncodeLen(len(data)))
err = EncodeTo(data, buf) _, err = EncodeTo(data, buf)
if err != nil { if err != nil {
panic(err) panic(err)
} }
b.SetBytes(int64(len(buf))) b.SetBytes(int64(len(buf)))
b.ResetTimer() b.ResetTimer()
for i := 0; i < b.N; i++ { for i := 0; i < b.N; i++ {
_ = DecodeTo(buf, data) _, _ = DecodeTo(buf, data)
} }
} }

View File

@@ -34,12 +34,7 @@ func (d *Decoder) Read(p []byte) (n int, err error) {
inlen = i + n inlen = i + n
if err != nil { if err != nil {
if inlen > 0 { if inlen > 0 {
offset := 0 n, _ = DecodeTo(d.b[:inlen], p)
if d.b[inlen-2] == '=' {
offset = int(d.b[inlen-1])
}
n = DecodeLen(inlen, offset)
_ = DecodeTo(d.b[:inlen], p)
d.b = nil d.b = nil
d.r = nil d.r = nil
} }
@@ -55,13 +50,11 @@ func (d *Decoder) Read(p []byte) (n int, err error) {
offset = int(d.b[inlen-1]) offset = int(d.b[inlen-1])
} }
if offset > 0 { if offset > 0 {
n = DecodeLen(len(d.b[:inlen]), offset) n, _ = DecodeTo(d.b[:inlen], p)
_ = DecodeTo(d.b[:inlen], p)
d.b = nil d.b = nil
d.r = nil d.r = nil
} else { } else {
n = DecodeLen(inlen, 0) n, _ = DecodeTo(d.b[:inlen], p)
_ = DecodeTo(d.b[:inlen], p)
d.b = d.b[:0] d.b = d.b[:0]
} }
return return
@@ -75,12 +68,7 @@ func (d *Decoder) Read(p []byte) (n int, err error) {
if len(d.b[inlen:]) == 2 { if len(d.b[inlen:]) == 2 {
inlen += 2 inlen += 2
} }
offset := 0 n, _ = DecodeTo(d.b[:inlen], p)
if d.b[inlen-2] == '=' {
offset = int(d.b[inlen-1])
}
n = DecodeLen(inlen, offset)
_ = DecodeTo(d.b[:inlen], p)
d.b = d.b[inlen:] d.b = d.b[inlen:]
return return
} }

View File

@@ -31,22 +31,19 @@ func (e *Encoder) Read(p []byte) (n int, err error) {
inlen = i + n inlen = i + n
if err != nil { if err != nil {
if len(e.b) > 0 { if len(e.b) > 0 {
n = EncodeLen(inlen) n, _ = EncodeTo(e.b[:inlen], p)
_ = EncodeTo(e.b[:inlen], p)
} }
e.b = nil e.b = nil
e.r = nil e.r = nil
return return
} }
n = EncodeLen(inlen) n, err = EncodeTo(e.b[:inlen], p)
err = EncodeTo(e.b[:inlen], p)
e.b = e.b[:0] e.b = e.b[:0]
return return
} else if inlen > len(e.b) { } else if inlen > len(e.b) {
inlen = len(e.b) inlen = len(e.b)
} }
n = EncodeLen(inlen) n, err = EncodeTo(e.b[:inlen], p)
err = EncodeTo(e.b[:inlen], p)
e.b = e.b[inlen:] e.b = e.b[inlen:]
return return
} }