You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
131 lines
2.1 KiB
131 lines
2.1 KiB
// run
|
|
|
|
// Copyright 2009 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// Test the internal "algorithms" for objects larger than a word: hashing, equality etc.
|
|
|
|
package main
|
|
|
|
type T struct {
|
|
a float64
|
|
b int64
|
|
c string
|
|
d byte
|
|
}
|
|
|
|
var a = []int{1, 2, 3}
|
|
var NIL []int
|
|
|
|
func arraycmptest() {
|
|
if NIL != nil {
|
|
println("fail1:", NIL, "!= nil")
|
|
panic("bigalg")
|
|
}
|
|
if nil != NIL {
|
|
println("fail2: nil !=", NIL)
|
|
panic("bigalg")
|
|
}
|
|
if a == nil || nil == a {
|
|
println("fail3:", a, "== nil")
|
|
panic("bigalg")
|
|
}
|
|
}
|
|
|
|
func SameArray(a, b []int) bool {
|
|
if len(a) != len(b) || cap(a) != cap(b) {
|
|
return false
|
|
}
|
|
if len(a) > 0 && &a[0] != &b[0] {
|
|
return false
|
|
}
|
|
return true
|
|
}
|
|
|
|
var t = T{1.5, 123, "hello", 255}
|
|
var mt = make(map[int]T)
|
|
var ma = make(map[int][]int)
|
|
|
|
func maptest() {
|
|
mt[0] = t
|
|
t1 := mt[0]
|
|
if t1.a != t.a || t1.b != t.b || t1.c != t.c || t1.d != t.d {
|
|
println("fail: map val struct", t1.a, t1.b, t1.c, t1.d)
|
|
panic("bigalg")
|
|
}
|
|
|
|
ma[1] = a
|
|
a1 := ma[1]
|
|
if !SameArray(a, a1) {
|
|
println("fail: map val array", a, a1)
|
|
panic("bigalg")
|
|
}
|
|
}
|
|
|
|
var ct = make(chan T)
|
|
var ca = make(chan []int)
|
|
|
|
func send() {
|
|
ct <- t
|
|
ca <- a
|
|
}
|
|
|
|
func chantest() {
|
|
go send()
|
|
|
|
t1 := <-ct
|
|
if t1.a != t.a || t1.b != t.b || t1.c != t.c || t1.d != t.d {
|
|
println("fail: map val struct", t1.a, t1.b, t1.c, t1.d)
|
|
panic("bigalg")
|
|
}
|
|
|
|
a1 := <-ca
|
|
if !SameArray(a, a1) {
|
|
println("fail: map val array", a, a1)
|
|
panic("bigalg")
|
|
}
|
|
}
|
|
|
|
type E struct{}
|
|
|
|
var e E
|
|
|
|
func interfacetest() {
|
|
var i interface{}
|
|
|
|
i = a
|
|
a1 := i.([]int)
|
|
if !SameArray(a, a1) {
|
|
println("interface <-> []int", a, a1)
|
|
panic("bigalg")
|
|
}
|
|
pa := new([]int)
|
|
*pa = a
|
|
i = pa
|
|
a1 = *i.(*[]int)
|
|
if !SameArray(a, a1) {
|
|
println("interface <-> *[]int", a, a1)
|
|
panic("bigalg")
|
|
}
|
|
|
|
i = t
|
|
t1 := i.(T)
|
|
if t1.a != t.a || t1.b != t.b || t1.c != t.c || t1.d != t.d {
|
|
println("interface <-> struct", t1.a, t1.b, t1.c, t1.d)
|
|
panic("bigalg")
|
|
}
|
|
|
|
i = e
|
|
e1 := i.(E)
|
|
// nothing to check; just verify it doesn't crash
|
|
_ = e1
|
|
}
|
|
|
|
func main() {
|
|
arraycmptest()
|
|
maptest()
|
|
chantest()
|
|
interfacetest()
|
|
}
|