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.
packer/vendor/github.com/modern-go/reflect2
chhaj5236 6b081cc41c
update alicloud builder to use official SDK (#7477)
7 years ago
..
.gitignore update alicloud builder to use official SDK (#7477) 7 years ago
.travis.yml update alicloud builder to use official SDK (#7477) 7 years ago
Gopkg.lock update alicloud builder to use official SDK (#7477) 7 years ago
Gopkg.toml update alicloud builder to use official SDK (#7477) 7 years ago
LICENSE update alicloud builder to use official SDK (#7477) 7 years ago
README.md update alicloud builder to use official SDK (#7477) 7 years ago
go_above_17.go update alicloud builder to use official SDK (#7477) 7 years ago
go_above_19.go update alicloud builder to use official SDK (#7477) 7 years ago
go_below_17.go update alicloud builder to use official SDK (#7477) 7 years ago
go_below_19.go update alicloud builder to use official SDK (#7477) 7 years ago
reflect2.go update alicloud builder to use official SDK (#7477) 7 years ago
reflect2_amd64.s update alicloud builder to use official SDK (#7477) 7 years ago
reflect2_kind.go update alicloud builder to use official SDK (#7477) 7 years ago
relfect2_386.s update alicloud builder to use official SDK (#7477) 7 years ago
relfect2_amd64p32.s update alicloud builder to use official SDK (#7477) 7 years ago
relfect2_arm.s update alicloud builder to use official SDK (#7477) 7 years ago
relfect2_arm64.s update alicloud builder to use official SDK (#7477) 7 years ago
relfect2_mips64x.s update alicloud builder to use official SDK (#7477) 7 years ago
relfect2_mipsx.s update alicloud builder to use official SDK (#7477) 7 years ago
relfect2_ppc64x.s update alicloud builder to use official SDK (#7477) 7 years ago
relfect2_s390x.s update alicloud builder to use official SDK (#7477) 7 years ago
safe_field.go update alicloud builder to use official SDK (#7477) 7 years ago
safe_map.go update alicloud builder to use official SDK (#7477) 7 years ago
safe_slice.go update alicloud builder to use official SDK (#7477) 7 years ago
safe_struct.go update alicloud builder to use official SDK (#7477) 7 years ago
safe_type.go update alicloud builder to use official SDK (#7477) 7 years ago
test.sh update alicloud builder to use official SDK (#7477) 7 years ago
type_map.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_array.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_eface.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_field.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_iface.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_link.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_map.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_ptr.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_slice.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_struct.go update alicloud builder to use official SDK (#7477) 7 years ago
unsafe_type.go update alicloud builder to use official SDK (#7477) 7 years ago

README.md

reflect2

Sourcegraph GoDoc Build Status codecov rcard License

reflect api that avoids runtime reflect.Value cost

  • reflect get/set interface{}, with type checking
  • reflect get/set unsafe.Pointer, without type checking
  • reflect2.TypeByName works like Class.forName found in java

json-iterator use this package to save runtime dispatching cost. This package is designed for low level libraries to optimize reflection performance. General application should still use reflect standard library.

reflect2.TypeByName

// given package is github.com/your/awesome-package
type MyStruct struct {
	// ...
}

// will return the type
reflect2.TypeByName("awesome-package.MyStruct")
// however, if the type has not been used
// it will be eliminated by compiler, so we can not get it in runtime

reflect2 get/set interface

valType := reflect2.TypeOf(1)
i := 1
j := 10
valType.Set(&i, &j)
// i will be 10

to get set type, always use its pointer *type

reflect2 get/set unsafe.Pointer

valType := reflect2.TypeOf(1)
i := 1
j := 10
valType.UnsafeSet(unsafe.Pointer(&i), unsafe.Pointer(&j))
// i will be 10

to get set type, always use its pointer *type

benchmark

Benchmark is not necessary for this package. It does nothing actually. As it is just a thin wrapper to make go runtime public. Both reflect2 and reflect call same function provided by runtime package exposed by go language.

unsafe safety

Instead of casting []byte to sliceHeader in your application using unsafe. We can use reflect2 instead. This way, if sliceHeader changes in the future, only reflect2 need to be upgraded.

reflect2 tries its best to keep the implementation same as reflect (by testing).