1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2025-01-04 16:37:12 -05:00

allocate buffer on stack

This commit is contained in:
Darien Raymond 2018-11-15 21:32:27 +01:00
parent a5ed9e00ab
commit a20262ef20
No known key found for this signature in database
GPG Key ID: 7251FFA14BB18169
5 changed files with 27 additions and 4 deletions

View File

@ -199,3 +199,11 @@ func New() *Buffer {
v: pool.Get().([]byte), v: pool.Get().([]byte),
} }
} }
// StackNew creates a new Buffer object on stack.
// This method is for buffers that is released in the same function.
func StackNew() Buffer {
return Buffer{
v: pool.Get().([]byte),
}
}

View File

@ -190,7 +190,7 @@ func (s *ServerSession) Handshake(reader io.Reader, writer io.Writer) (*protocol
// | 1 | 1 | 1 to 255 | 1 | 1 to 255 | // | 1 | 1 | 1 to 255 | 1 | 1 to 255 |
// +----+------+----------+------+----------+ // +----+------+----------+------+----------+
func ReadUsernamePassword(reader io.Reader) (string, string, error) { func ReadUsernamePassword(reader io.Reader) (string, string, error) {
buffer := buf.New() buffer := buf.StackNew()
defer buffer.Release() defer buffer.Release()
if _, err := buffer.ReadFullFrom(reader, 2); err != nil { if _, err := buffer.ReadFullFrom(reader, 2); err != nil {
@ -220,7 +220,7 @@ func ReadUsernamePassword(reader io.Reader) (string, string, error) {
// ReadUntilNull reads content from given reader, until a null (0x00) byte. // ReadUntilNull reads content from given reader, until a null (0x00) byte.
func ReadUntilNull(reader io.Reader) (string, error) { func ReadUntilNull(reader io.Reader) (string, error) {
b := buf.New() b := buf.StackNew()
defer b.Release() defer b.Release()
for { for {

View File

@ -4,6 +4,7 @@ import (
"bytes" "bytes"
"testing" "testing"
"v2ray.com/core/common"
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
"v2ray.com/core/common/net" "v2ray.com/core/common/net"
_ "v2ray.com/core/common/net/testing" _ "v2ray.com/core/common/net/testing"
@ -107,3 +108,17 @@ func TestReadUntilNull(t *testing.T) {
} }
} }
} }
func BenchmarkReadUsernamePassword(b *testing.B) {
input := []byte{0x05, 0x01, 'a', 0x02, 'b', 'c'}
buffer := buf.New()
buffer.Write(input)
b.ResetTimer()
for i := 0; i < b.N; i++ {
_, _, err := ReadUsernamePassword(buffer)
common.Must(err)
buffer.Clear()
buffer.Extend(int32(len(input)))
}
}

View File

@ -164,7 +164,7 @@ func (c *ClientSession) DecodeResponseHeader(reader io.Reader) (*protocol.Respon
aesStream := crypto.NewAesDecryptionStream(c.responseBodyKey[:], c.responseBodyIV[:]) aesStream := crypto.NewAesDecryptionStream(c.responseBodyKey[:], c.responseBodyIV[:])
c.responseReader = crypto.NewCryptionReader(aesStream, reader) c.responseReader = crypto.NewCryptionReader(aesStream, reader)
buffer := buf.New() buffer := buf.StackNew()
defer buffer.Release() defer buffer.Release()
if _, err := buffer.ReadFullFrom(c.responseReader, 4); err != nil { if _, err := buffer.ReadFullFrom(c.responseReader, 4); err != nil {

View File

@ -70,7 +70,7 @@ func (w *KCPPacketWriter) Overhead() int {
} }
func (w *KCPPacketWriter) Write(b []byte) (int, error) { func (w *KCPPacketWriter) Write(b []byte) (int, error) {
bb := buf.New() bb := buf.StackNew()
defer bb.Release() defer bb.Release()
if w.Header != nil { if w.Header != nil {