我的问题是:
- 为什么这个错误没有被抛出到代码中?
- 我怎样才能让错误被抛出到代码中?
我在哪里/我怎么能自己解决这个问题?/ 这个“功能”的文档在哪里?
Function demo_problem { describe_global_error_variable $ret_value = "be loud please".extended_property write-host "returned a value=[$ret_value]." describe_global_error_variable } Function describe_global_error_variable { $cnt = $Error.Count write-host "`$Error .Count=[$($cnt)]." $i=0 while ($i -lt $cnt) { write-host "`$Error[$i].Exception.Message=[$($Error[$i].Exception.Message)]" $i += 1 } } $script_block_throws = { write-host "at beginning of script_block for script_block_throws. `$this=[$this]." 1/0 return $true write-host "at end of script_block for script_block_throws. `$this=[$this]." } $script_block_try_catch_throw = { write-host "at beginning of script_block for script_block_try_catch_throw. `$this=[$this]." try { 1/0 return $true } catch [Exception]{ write-host "script_block_try_catch_throw caught an exception" throw "caught an exception" } return $false write-host "at end of script_block for script_block_try_catch_throw. `$this=[$this]." } try { Update-TypeData -Value:$script_block_throws -TypeName:System.String -MemberName:extended_property -Force -MemberType:ScriptProperty demo_problem Update-TypeData -Value:$script_block_try_catch_throw -TypeName:System.String -MemberName:extended_property -Force -MemberType:ScriptProperty demo_problem } catch [Exception]{ write-host "exception got thrown out of the script block...." } <# PS C:\ .\powershell_call_to_extended_property_fails_silently.ps1 $Error .Count=[0]. \ at beginning of script_block for script_block_throws. $this=[be loud please]. returned a value=[]. $Error .Count=[1]. \ $Error[0].Exception.Message=[Attempted to divide by zero.] $Error .Count=[1]. \ $Error[0].Exception.Message=[Attempted to divide by zero.] at beginning of script_block for script_block_try_catch_throw. $this=[be loud please]. script_block_try_catch_throw caught an exception returned a value=[]. $Error .Count=[3]. \ $Error[0].Exception.Message=[caught an exception] $Error[1].Exception.Message=[Attempted to divide by zero.] $Error[2].Exception.Message=[Attempted to divide by zero.] #>