dsgwii4867 2019-08-02 09:17
浏览 86

类型名称*名称如何工作?

I was looking at some examples on golang.org homepage and found Peano Integers. This example defines the type Number like this:

type Number *Number

First time looking at this code I thought it should not compile, I think I haven't understood how type works in Go.

Can you explain how Go is defining type Number here? This looks very confusing to me.

Go Playground

// Peano integers are represented by a linked
// list whose nodes contain no data
// (the nodes are the data).
// http://en.wikipedia.org/wiki/Peano_axioms

// This program demonstrates that Go's automatic
// stack management can handle heavily recursive
// computations.

package main

import "fmt"

// Number is a pointer to a Number
type Number *Number

// The arithmetic value of a Number is the
// count of the nodes comprising the list.
// (See the count function below.)

// -------------------------------------
// Peano primitives

func zero() *Number {
    return nil
}

func isZero(x *Number) bool {
    return x == nil
}

func add1(x *Number) *Number {
    e := new(Number)
    *e = x
    return e
}

func sub1(x *Number) *Number {
    return *x
}

func add(x, y *Number) *Number {
    if isZero(y) {
        return x
    }
    return add(add1(x), sub1(y))
}

func mul(x, y *Number) *Number {
    if isZero(x) || isZero(y) {
        return zero()
    }
    return add(mul(x, sub1(y)), x)
}

func fact(n *Number) *Number {
    if isZero(n) {
        return add1(zero())
    }
    return mul(fact(sub1(n)), n)
}

// -------------------------------------
// Helpers to generate/count Peano integers

func gen(n int) *Number {
    if n > 0 {
        return add1(gen(n - 1))
    }
    return zero()
}

func count(x *Number) int {
    if isZero(x) {
        return 0
    }
    return count(sub1(x)) + 1
}

// -------------------------------------
// Print i! for i in [0,9]

func main() {
    for i := 0; i <= 9; i++ {
        f := count(fact(gen(i)))
        fmt.Println(i, "! =", f)
    }
}

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
    • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
    • ¥16 mybatis的代理对象无法通过@Autowired装填
    • ¥15 可见光定位matlab仿真
    • ¥15 arduino 四自由度机械臂
    • ¥15 wordpress 产品图片 GIF 没法显示
    • ¥15 求三国群英传pl国战时间的修改方法
    • ¥15 matlab代码代写,需写出详细代码,代价私
    • ¥15 ROS系统搭建请教(跨境电商用途)
    • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。