mirror of
https://github.com/impact-eintr/netstack.git
synced 2025-10-05 12:56:55 +08:00
35 lines
773 B
Go
35 lines
773 B
Go
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
|
||
}
|