这个Go打印声明的顺序是什么?

时间:2015-09-16 21:07:38

标签: go println

我正在参加关于Golang的“GO之旅”教程和这段代码:

package main

import (
    "fmt"
    "math"
)

func pow(x, n, lim float64) float64 {
    if v := math.Pow(x, n); v < lim {
        return v
    } else {
        fmt.Printf("%g >= %g\n", v, lim)
    }
    // can't use v here, though
    return lim
}

func main() {
    fmt.Println(
        pow(3, 2, 10),
        pow(3, 3, 20),
    )
}

会打印出来 “27&gt; = 20 9 20”。

我很困惑,为什么不是 “9 27&gt; = 20 20”

第一次打电话给pow(3,2,10)不应该返回9,打印它,然后打电话给pow(3,3,20)并打印其余部分?

2 个答案:

答案 0 :(得分:5)

这实际上有点微妙,让我困惑了一秒钟。 “秘密”是函数必须在调用之前评估其所有参数。所以它调用函数两次得到9和20,但其中一个评估碰巧叫Println。

为什么语言在调用函数之前评估它的参数是相当简单的(当涉及副作用时,这种部分应用程序很棘手,并且主要是为函数式语言保留),但隐藏了具有副作用的函数,例如在内部打印为了清楚起见,可能不鼓励进行功能评估。

代码可能更直接:

    nam = driver.find_element(By.CLASS_NAME ,'_wu')

    #get length of review
    revcnt = driver.find_element(By.XPATH ,"//span[@class='_Mnc _yz']")
    revcnt = int(revcnt.text.replace(" reviews","").strip())
    print revcnt
    # wait for reviews to appear
    wait = WebDriverWait(driver, 10)
    wait.until(EC.visibility_of_element_located((By.CSS_SELECTOR, "span.review-snippet")))
    #reviews=[]
    while True:
        reviews = driver.find_elements_by_css_selector("div._ju")
        if len(reviews)<revcnt:
            driver.execute_script("arguments[0].scrollIntoView();", reviews[-1])
        else:
            driver.quit()
        print len(reviews)

答案 1 :(得分:2)

fmt.Println()在调用之前需要所有参数。

所以,你有9,但是当你得到另一个值(20)时,控制台会输出其他内容。

just like this

package main

import "fmt"

func main() {

    fmt.Println(9, f())
}
func f() int {
    fmt.Println("This gets printed before")
    return 20
}

输出:

This gets printed before
9 20