mirror of
https://github.com/impact-eintr/netstack.git
synced 2025-10-06 05:16:50 +08:00
tcp可靠性实现 抄了一堆东西 信息量太大了 看不过来
This commit is contained in:
34
tcpip/transport/tcp/segment_heap.go
Normal file
34
tcpip/transport/tcp/segment_heap.go
Normal file
@@ -0,0 +1,34 @@
|
||||
package tcp
|
||||
|
||||
// tcp段的堆,用来暂存失序的tcp段
|
||||
// 实现了堆排序
|
||||
type segmentHeap []*segment
|
||||
|
||||
// Len returns the length of h.
|
||||
func (h segmentHeap) Len() int {
|
||||
return len(h)
|
||||
}
|
||||
|
||||
// Less determines whether the i-th element of h is less than the j-th element.
|
||||
func (h segmentHeap) Less(i, j int) bool {
|
||||
return h[i].sequenceNumber.LessThan(h[j].sequenceNumber)
|
||||
}
|
||||
|
||||
// Swap swaps the i-th and j-th elements of h.
|
||||
func (h segmentHeap) Swap(i, j int) {
|
||||
h[i], h[j] = h[j], h[i]
|
||||
}
|
||||
|
||||
// Push adds x as the last element of h.
|
||||
func (h *segmentHeap) Push(x interface{}) {
|
||||
*h = append(*h, x.(*segment))
|
||||
}
|
||||
|
||||
// Pop removes the last element of h and returns it.
|
||||
func (h *segmentHeap) Pop() interface{} {
|
||||
old := *h
|
||||
n := len(old)
|
||||
x := old[n-1]
|
||||
*h = old[:n-1]
|
||||
return x
|
||||
}
|
Reference in New Issue
Block a user