每次执行脚本时重新加载PowerShell模块 [英] Reload the PowerShell module every time the script is executing
本文介绍了每次执行脚本时重新加载PowerShell模块的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我在PowerShell模块文件中有一个类。(A.psm1
)
class A {
[void] printString() {
write-host 111
}
}
我还有一个使用该类的简单脚本。
Using module C: empA.psm1
$a = [A]::new()
$a.printString() # prints 111
但如果我更改类中的方法,例如,如下所示(在222
上替换111
)
[void] printString() {
write-host 222
}
如果我重新启动脚本,它仍将打印111
。仅当我重新启动PowerShell控制台时,它才会打印新值。
如果我只在控制台中工作,我可以使用Import-Module ... -Force
命令。但它在脚本中不起作用。
是否可以在每次启动脚本时重新加载PowerShell模块,而无需重新启动控制台本身?
推荐答案
此不幸行为是well-known issue,并且as mklement0 points out当前没有真正的好解决方案。
根本原因有点错综复杂(行为在5年多之后仍然存在的部分原因),但基本上是以下三方面的冲突:
- PowerShell中的模块生命周期管理(假设可重新加载)
- .NET中的类型定义生命周期管理(在进程的整个生命周期内,类型永远不能是未定义的*)
using module
方式提供自定义类型的分析时解析-简单地说,它不是一个特别成熟的功能
虽然没有好的解决方案,但VSCode PowerShell扩展有一个配置选项allowing you to run debug sessions in a temporary shell,因此不会出现问题:
{
"powershell.debugging.createTemporaryIntegratedConsole": true
}
设置后,您可以使用以下工作流进行测试/调试:
- 在编辑器中打开脚本
- 通过调试器运行(
Shift+Ctrl+D
->;Run and Debug
) - 观察
printString()
打印111
- 更改模块文件并保存
- 再次通过调试器运行脚本
- 观察
printString()
现在打印新值
这篇关于每次执行脚本时重新加载PowerShell模块的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文