PowerShell:不能将局部变量限定在类方法内?

问题描述 投票:0回答:2

我希望在类方法内部,我可以在方法内部设置“本地”变量范围,但事实并非如此。以下是测试代码:

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 下测试过。

powershell oop powershell-5.0 powershell-7.0
2个回答
4
投票

这很令人惊讶。我怎样才能有局部变量?

您可以在类方法中拥有所有您想要的局部变量 - 只要它们的名称不与任何类成员名称冲突

class MyClass
{
  [string]$var

  MyMethod()
  {
    $somethingOtherThanVar = "this should work"
  }
}

reason PowerShell 抛出错误是故意的helpful - 新接触语言或类定义功能的类作者可能会在方法中分配给

$var
,认为
$this.var
(声明因为
$var
在方法体之外)会反映作业并带来令人讨厌的惊喜。


0
投票

接受的答案避免了问题,但没有确定其根本原因。这是必须始终在类函数中指定变量的范围,函数接收的参数和类属性除外。所以你可以毫无问题地写作:

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'
© www.soinside.com 2019 - 2024. All rights reserved.