1 #Region "Microsoft.VisualBasic::c7aea5ec8ecbd6f1b5aa808239d26fc9, Microsoft.VisualBasic.Core\ApplicationServices\Tools\Network\Protocol\Streams\ArrayBase.vb"
2
3     ' Author:
4     
5     '       asuka (amethyst.asuka@gcmodeller.org)
6     '       xie (genetics@smrucc.org)
7     '       xieguigang (xie.guigang@live.com)
8     
9     ' Copyright (c) 2018 GPL3 Licensed
10     
11     
12     ' GNU GENERAL PUBLIC LICENSE (GPL3)
13     
14     
15     ' This program is free software: you can redistribute it and/or modify
16     ' it under the terms of the GNU General Public License as published by
17     ' the Free Software Foundation, either version 3 of the License, or
18     ' (at your option) any later version.
19     
20     ' This program is distributed in the hope that it will be useful,
21     ' but WITHOUT ANY WARRANTY; without even the implied warranty of
22     ' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23     ' GNU General Public License for more details.
24     
25     ' You should have received a copy of the GNU General Public License
26     ' along with this program. If not, see <http://www.gnu.org/licenses/>.
27
28
29
30     ' /********************************************************************************/
31
32     ' Summaries:
33
34     '     Class ValueArray
35     
36     '         Constructor: (+1 OverloadsSub New
37     '         FunctionToString
38     
39     
40     ' /********************************************************************************/
41
42 #End Region
43
44 Imports Microsoft.VisualBasic.Language
45 Imports Microsoft.VisualBasic.Linq.Extensions
46 Imports System.Xml.Serialization
47
48 Namespace Net.Protocols.Streams.Array
49
50     ''' <summary>
51     ''' 对于<see cref="System.Int64"/>, <see cref="System.int32"/>, <see cref="System.Double"/>, <see cref="System.DateTime"/>
52     ''' 这些类型的数据来说,进行网络传输的时候使用json会被转换为字符串,数据量比较大,而转换为字节再进行传输,数据流量的消耗会比较小
53     ''' </summary>
54     ''' <typeparam name="T"></typeparam>
55     ''' <remarks>这个是定长的数组序列</remarks>
56     Public MustInherit Class ValueArray(Of T) : Inherits ArrayAbstract(Of T)
57
58         Protected ReadOnly _bufWidth As Integer
59
60         Protected Sub New(serialization As Func(Of T, Byte()),
61                           deserialization As Func(Of Byte(), T),
62                           bufWidth As Integer,
63                           rawStream As Byte())
64
65             Call MyBase.New(serialization, deserialization)
66
67             _bufWidth = bufWidth
68
69             If Not rawStream.IsNullOrEmpty Then
70                 Dim valueList As New List(Of T)
71                 Dim p As int = 0
72                 Dim byts As Byte() = New Byte(_bufWidth - 1) {}
73
74                 Do While p < rawStream.Length - 1
75                     Call System.Array.ConstrainedCopy(rawStream, p + bufWidth, byts, Scan0, bufWidth)
76                     Call valueList.Add(__deserialization(byts))
77                 Loop
78
79                 Values = valueList.ToArray
80             End If
81         End Sub
82
83         Public NotOverridable Overrides Function Serialize() As Byte()
84             Dim buffer As Byte() = New Byte(Values.Length * _bufWidth - 1) {}
85             Dim p As int = 0
86
87             For Each value As T In Values
88                 Dim byts As Byte() = __serialization(value)
89                 Call System.Array.ConstrainedCopy(byts, Scan0, buffer, p + _bufWidth, _bufWidth)
90             Next
91
92             Return buffer
93         End Function
94
95         Public Overrides Function ToString() As String
96             If Values.IsNullOrEmpty Then
97                 Return GetType(T).FullName
98             Else
99                 Return $"{GetType(T).FullName}  {"{"}{String.Join("," & vbTab, Values.Select(Function(val) Scripting.ToString(val)).ToArray)}{"}"}"
100             End If
101         End Function
102     End Class
103 End Namespace