struct.go 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /*
  2. * @description:struct相关知识
  3. * @Author: CP
  4. * @Date: 2020-08-21 09:34:47
  5. * @FilePath: \construction_management\learn\struct.go
  6. */
  7. package learn
  8. import (
  9. "fmt"
  10. )
  11. /*
  12. 没有class,只有struct结构体
  13. 没有构造函数,可以加工厂函数来构造
  14. 结构体过大也考虑使用指针接收者
  15. 结构体的方法的封装
  16. 首字母大写:public
  17. 首字母小写:private 只是针对包
  18. 每个目录一个包,为结构体定义的方法必须在同一个包内
  19. 结构体的方法可以分散在不同的文件内,同一个包内
  20. 扩展其他人写的包-学习go语言4-3
  21. */
  22. type TreeNode struct {
  23. Value int
  24. // *类型是指针
  25. Left, Right *TreeNode
  26. }
  27. //为结构定义方法-方法名称前 定义好 (node treeNode)
  28. //显示定义和命名方法接收者
  29. func (node TreeNode) Print() {
  30. fmt.Println(node.Value)
  31. }
  32. //这里不使用指针是改不掉里面的值 node treeNode,需要指针
  33. //只有使用指针才可以改变结构内容 nil指针也能调用方法
  34. func (node *TreeNode) SetValue(value int) {
  35. node.Value = value
  36. }
  37. //遍历结构体treeNode
  38. func (node *TreeNode) Traveres() {
  39. if node == nil {
  40. return
  41. }
  42. //如果在其他语言node.left是nil调用traveres()会挂掉,在go语言中不会
  43. node.Left.Traveres()
  44. node.Print()
  45. node.Left.Traveres()
  46. node.Print()
  47. }
  48. //工厂函数来构造treeNode
  49. func CreateTreeNode(value int) *TreeNode {
  50. return &TreeNode{Value: value}
  51. }
  52. // func main() {
  53. // // 创建结构的方式1
  54. // var root2 treeNode
  55. // fmt.Println(root2)
  56. // // 创建结构的方式2
  57. // root := treeNode{value: 3}
  58. // //&取地址
  59. // root.left = &treeNode{}
  60. // // 创建结构的方式3
  61. // root.left.right = new(treeNode)
  62. // // 创建结构的方式4
  63. // root.left.left = createTreeNode(2)
  64. // // 创建结构的方式5
  65. // node := []treeNode{
  66. // {value: 3},
  67. // {},
  68. // {6, nil, nil},
  69. // }
  70. // fmt.Println(node)
  71. // //调用结构体方法
  72. // root.print()
  73. // root.right.left.setValue(2)
  74. // root.right.left.print()
  75. // root.traveres()
  76. // }