我希望在类方法内部,我可以在方法内部设置“本地”变量范围,但事实并非如此。以下是测试代码:
class test_scope {
$var = "class var"
test_scope() {
}
[void] my_method() {
$var = "method var"
}
}
$obj = [test_scope]::new()
$obj.my_method()
我收到一条错误消息:
Line |
8 | $var = "method var"
| ~~~~
| Cannot assign property, use '$this.var'.
这很令人惊讶。我怎样才能有局部变量?
作为比较,函数(即在类之外)可以具有与脚本变量同名的局部变量。下面是一个例子:
$var2="global var"
function my_function() {
$var2="function var"
write-host $var2
write-host $script:var2
}
my_function($null)
我得到了我期望的答案:
function var
global var
与 Python 的另一个比较:
class test_scope:
var = "class var"
def my_method(self):
var = "method var"
print(self.var)
print(var)
obj = test_scope()
obj.my_method()
它按预期工作:
function var
global var
所以 PowerShell 不正常?
PS:我在 PowerShell 5.0 和 7.0 下测试过。
这很令人惊讶。我怎样才能有局部变量?
您可以在类方法中拥有所有您想要的局部变量 - 只要它们的名称不与任何类成员名称冲突:
class MyClass
{
[string]$var
MyMethod()
{
$somethingOtherThanVar = "this should work"
}
}
reason PowerShell 抛出错误是故意的helpful - 新接触语言或类定义功能的类作者可能会在方法中分配给
$var
,认为$this.var
(声明因为 $var
在方法体之外)会反映作业并带来令人讨厌的惊喜。
接受的答案避免了问题,但没有确定其根本原因。这是必须始终在类函数中指定变量的范围,函数接收的参数和类属性除外。所以你可以毫无问题地写作:
class test_scope {
$var = "class var"
test_scope() {
}
[void] my_method() {
$local:var = "local method var" # or private
$script:var = "script var" # or global
# one can omit local or private scope when reading the variable:
Write-Host "'$var' vs '$( $this.var )'"
# one has to use global or script scope also when reading the variable:
Write-Host "'$( $script:var )' vs '$( $this.var )'" # or global
}
}
$obj = [test_scope]::new()
$obj.my_method()
输出:
'local method var' vs 'class var'
'script var' vs 'class var'