비교 가능한 인터페이스를 무엇이라고 하나요?
Go에는 일반 비교 연산자(<)를 제공하는 미리 정의된 인터페이스가 없습니다. 대신, 자신만의 Less 함수를 정의하여 유형을 비교할 수 있습니다. Less 함수는 동일한 유형의 두 인수를 사용하고 첫 번째 인수가 두 번째 인수보다 작은지 여부를 나타내는 부울을 반환합니다.
다음은 정수와 문자열을 비교할 수 있는 Less 함수의 예입니다.
func Less(a, b interface{}) bool { switch a.(type) { case int: if ai, ok := a.(int); ok { if bi, ok := b.(int); ok { return ai < bi } } case string: if ai, ok := a.(string); ok { if bi, ok := b.(string); ok { return ai < bi } } // ... default: panic("Unknown") } return false }
Less 함수를 사용하여 정렬된 연결 목록에 요소를 삽입할 수 있습니다.
func Insert(val interface{}, l *list.List) *list.Element { e := l.Front() if e == nil { return l.PushFront(val) } for ; e != nil; e = e.Next() { if Less(val, e.Value) { return l.InsertBefore(val, e) } } return l.PushBack(val) }
이 삽입 함수는 Less 함수를 기반으로 정렬된 순서로 연결 목록을 유지합니다.
위 내용은 Go에서 일반 비교 연산자를 어떻게 구현할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!