【发布时间】:2012-10-30 21:51:43
【问题描述】:
例如,如果您尝试(+ 3 4),具体是如何在源中分解和计算的?它是否使用add1 的递归?
【问题讨论】:
例如,如果您尝试(+ 3 4),具体是如何在源中分解和计算的?它是否使用add1 的递归?
【问题讨论】:
+ 的实现实际上比您想象的要复杂得多,因为算术在 Racket 中是通用的:它适用于整数、有理数、复数等。你甚至可以混合和匹配这些类型的数字,它会做正确的事情。最后,它最终将使用 C 中的算术,这就是编写运行时系统的内容。
如果您好奇,可以在这里找到更多关于数字塔的内容:https://github.com/plt/racket/blob/master/src/racket/src/numarith.c
其他指针:Bignum arithmetic、Scheme numeric tower、numbers 上的 Racket 引用。
【讨论】:
+ 操作符是一种原始操作,是核心语言的一部分。出于效率原因,将其实现为递归过程没有多大意义。
【讨论】: