def make_funcs():
fs = []
for i in range(3):
def f():
return i
fs.append(f)
return fs
funcs = make_funcs()
print()
A.
B.
C.
D. 抛出 NameError haly 发表于 2026-04-01 06:47
@FishC 执行以下代码后,输出结果是什么?
def mak ...
输出结果是 ,所以选 B。
解释:在 make_funcs 函数中,循环创建了三个函数 f,它们都引用了变量 i。但由于 Python 闭包的迟绑定特性,函数在被调用时才会查找 i 的值。循环结束后,i 的最终值为 2,因此所有函数调用时都返回 2。
def make_funcs():
fs = []
for i in range(3):
def f():
return i
fs.append(f)
return fs
funcs = make_funcs()
print()# 输出
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 @FishC 下列代码会报什么错误?
def outer():
def inner():
nonlocal x
x = 1
return inner
A. NameError: x is not defined
B. UnboundLocalError
C. SyntaxError(no binding for nonlocal 'x' found)
D. TypeError haly 发表于 2026-04-01 06:47
@FishC 下列代码会报什么错误?
def outer():
...
该代码会报语法错误,因为 nonlocal 语句要求变量 x 必须在嵌套作用域(即外层函数 outer)中已定义,但此处并未定义。Python 在编译函数定义时会检测到这一问题,并抛出 SyntaxError。
错误信息通常为:SyntaxError: no binding for nonlocal 'x' found,因此正确选项是 C。
# 错误示例
def outer():
def inner():
nonlocal x# 这里会报错,因为 outer 中没有定义 x
x = 1
return inner
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 @FishC 执行以下代码后,输出结果是什么?
len = lambda x: 100
def make():
def inner():
return len()
return inner
f = make()
print(f())
A. 3
B. 100
C. TypeError: 'int' object is not callable
D. NameError: name 'len' is not defined haly 发表于 2026-04-02 05:42
@FishC 执行以下代码后,输出结果是什么?
len = l ...
执行以下代码后,输出结果是 B. 100。
解释:
首先,在全局作用域中,变量 len 被重新赋值为一个 lambda 函数:lambda x: 100,这覆盖了内置的 len 函数。
在 make 函数中定义的 inner 函数里,调用 len() 时,Python 会按照作用域链查找 len。由于在 inner 和 make 的作用域内都没有定义 len,因此找到全局作用域中的 len,即返回 100 的 lambda 函数。
因此,f() 返回 100,最终打印输出 100。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页:
[1]