- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我无法让PowerShell调用提供的回调:
$rs = [RunspaceFactory]::CreateRunspace()
$rs.Open()
$ps = [PowerShell]::Create()
$ps.Runspace = $rs
$ps.AddScript( {
Get-Service
} ) | Out-Null
$psdcInputs = New-Object Management.Automation.PSDataCollection[String]
$psdcInputs.Complete()
$psdcOutputs = New-Object Management.Automation.PSDataCollection[Object]
$psis = New-Object Management.Automation.PSInvocationSettings
$asyncCallback = {
Param (
[IAsyncResult]$result
)
Write-EventLog -LogName Application -Source Testing -EntryType Information `
-Category 0 -EventId 1234 -Message "Test."
$result.AsyncState.EndInvoke($result)
}
$aResult = $ps.BeginInvoke($psdcInputs, $psdcOutputs, $psis, $asyncCallback, $ps)
scriptblock
运行,并且
$psdcOutputs
包含一组
ServiceController
对象。但是
$asyncCallback
scriptblock
中的代码未运行,并且该事件未写入事件日志。我看不到我在做什么错。你能帮忙吗?
最佳答案
AsyncCallbacks,Actions,EventHandlers等...大多在后台进程中运行
因此无法访问主线程中的变量。
事件发布者总是将自己和一组预定义的事件参数传递给
你的经理。这些事件参数的内容由
Activity ,您对此无话可说。除非您使用C#路线。
但是..... Add-Member是您的救星。我已重新编写您的样本以演示
我正在谈论的概念。
$asyncCallback = {
Param (
# Event source object
[System.Management.Automation.Powershell]
$sender,
# Inheritor of [System.EventArgs]
[System.Management.Automation.PSInvocationStateChangedEventArgs]
$e
)
# Ignore initial state change on startup
if ($e.InvocationStateInfo.State -eq [System.Management.Automation.PSInvocationState]::Running)
{
return
}
Write-Host $sender.Message
Write-Host "Event Fired!"
Write-Host ("Invocation State: {0}" -f $e.InvocationStateInfo.State)
#Write-EventLog -LogName Application -Source Testing -EntryType Information `
# -Category 0 -EventId 1234 -Message "Test."
# Use the NoteProperty references attached to the Powershell object by Add-Member
[void]$sender.EndInvoke($sender.AsyncResult)
# Clean up if you like
$sender.Dispose()
#
# You can unregister the event from within the event handler, but you
# shouldn't do so if you plan on recycling/restarting the background
# powershell instance.
#
# Unregister the event subscription
Unregister-Event -SourceIdentifier $sender.EventSubscriber.Name
#
# WARNING!
# Call To Remove-Job From Parent Thread!
#
# You cannot dispose of the EventJob (THIS) from within the job itself.
# That would kind of be like a snake trying to eat it's own tail...
#
# As such, you should be very careful about how you remove background jobs. If
# you use the command sequence below from anywhere within your main thead, you
# will break this event handler (and any others created by Register-ObjectEvent).
#
# (Dispose of Job)
# Get-Job | Remove-Job
#
}
<#
# This section is unnecessary unless you are modifying the apartment state
# of the runspace before opening it. The shell returned by Create() already
# has a runspace.
#
# $rs = [RunspaceFactory]::CreateRunspace()
# $rs.Open()
# $ps.Runspace = $rs
#>
$ps = [PowerShell]::Create().AddScript( {
#Get-Service
Get-Process
Start-Sleep -Seconds 2
} )
#
# Subscribe to the Powershell state changed event. Attach the registration object
# to the Powershell object for future reference.
#
Add-Member -InputObject $ps -MemberType NoteProperty -Name EventSubscriber -Value (
Register-ObjectEvent -InputObject $ps -EventName InvocationStateChanged -Action $asyncCallback)
<#
# This call structure is unnecessary as you aren't using the InvocationSettings
#
# $psis = New-Object Management.Automation.PSInvocationSettings
# $aResult = $ps.BeginInvoke($psdcInputs, $psdcOutputs, $psis, $asyncCallback, $ps)
#>
#
# Initialize invocation parameters
#
# Attach references to any data/objects/scriptblocks that you must be accessable
# within your event handler using Add-Member.
#
Add-Member -InputObject $ps -MemberType NoteProperty -Name Message -Value (
"Hello World! It's Me {0}" -f $ps.EventSubscriber.Name)
$psdcInputs = New-Object Management.Automation.PSDataCollection[String]
$psdcInputs.Complete()
$psdcOutputs = New-Object Management.Automation.PSDataCollection[Object]
Add-Member -InputObject $ps -MemberType NoteProperty -Name AsyncResult -Value (
$ps.BeginInvoke($psdcInputs, $psdcOutputs))
# Watch for race conditions
Start-Sleep -Seconds 10
# Kill all remaining background jobs (including the EventJob asyncCallback)
Get-Job
Get-Job | Remove-Job | Out-Null
关于powershell - 为什么PowerShell.BeginInvoke不调用回调?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27405657/
我对 Dispatcher.CurrentDispatcher.BeginInvoke 和 BeginInvoke 之间的区别感到困惑 我有以下部分代码不起作用,UpdateCounts 方法中的代码
我最初尝试使用 Dispatcher 类 BeginInvoke 方法在我的 C# Windows 窗体应用程序的主 UI 线程上显示消息框。当我使用该方法时,消息框没有出现。我在传递给 BeginI
伙计们! 我的.net应用程序有问题。当我尝试在程序中打印时,它会崩溃崩溃 与任何错误消息。我从Windows中的事件查看器中获得的有关错误的信息。有人能帮我吗?但是在另一台计算机上它可以正常工作。我
我有简单的(我认为的)逻辑。 public static void NotifyAboutNewJob(int jobId, bool forceSending = false) {
我有一个 c# .NET winforms 应用程序进行此异步调用: simpleDelegate.BeginInvoke(null, null); 委托(delegate)正在调用我的函数,一切正常
1) 我听说当我们不调用 EndInvoke() 时可能会导致内存泄漏?你能演示一下这怎么会导致内存泄漏吗? 2) 当我想调用 EndInvoke() 时,我应该使用如下代码吗? namespace
我遇到了在多线程应用程序中使用 Dispatcher.BeginInvoke 导致的我无法理解的错误。 我的程序包含一个 List 对象,我使用多个线程循环遍历这些对象并执行一些计算。我已将我的代码结
我正在研究其他人的代码,但对多线程没有太多经验。我遇到了这行代码: BeginInvoke((MethodInvoker)delegate() { btnCalibrate.PerformClick(
我继承了从主线程调用 BeginInvoke 的代码(不是后台线程,通常是这种模式)。我试图了解它在这种情况下的实际作用。 在 BeginInvoke 中调用的方法是否符合下行到窗口的消息?文档说 a
为什么会出现此错误以及如何修复它。感谢帮助 错误 4 无法将 lambda 表达式转换为类型“System.Delegate”,因为它不是委托(delegate)类型 void provide
我在 WPF 应用程序中有一些代码如下所示: public class MyTextBox : System.Windows.Controls.TextBox, IDisposable { p
我有以下问题。 FindRoot 实际上在第三方 dll 中,我无法控制它。 它必须通过 Begin invoke 调用。有时,FindRoot 方法会抛出异常。这导致我的整个应用程序崩溃。现在,即使
这个问题在这里已经有了答案: Does Func.BeginInvoke use the ThreadPool? (2 个答案) 关闭 1 年前。 在我的 WPF 应用程序中,我想在非 UI 线程中
我是线程和异步编程的新手。我正在尝试学习这些概念,到目前为止,我已经理解了,但是还有一个问题要问。 可以说我想调用一个名为GetAllUsers()的方法,该方法需要很长时间才能执行,因此它不会阻塞资
我已经看到(并阅读)关于使用 Dispatcher.BeginInvoke 来确保 UI 更新发生在 UI 线程上。我明白这个道理。 但是我看到了在 View 代码隐藏中分配属性(例如 TextBlo
我想确定使用 BeginInvoke 时执行处理程序的线程。现在,每次我调用该方法时,处理程序都会由不同的线程执行。有没有办法确定线程? using System; using System.Thre
我有一个长时间运行的函数¹: public string FindPasswordFromHash(String hash) { ... } 它被称为: private void Button
我找不到这个简单问题的答案:BeginInvoke() 是否保证以原子方式执行被调用的委托(delegate)?例如,如果我有类似的东西 public ObservableCollection Ite
我收到一个 InvalidOperationException 消息 Cross-thread operation not valid.. _waitForm 是在主窗体的构造函数中创建的。屏幕截图中
我是编码新手,在我的第一个项目中,我必须从数显卡尺读取信息并将其显示在网络应用程序的文本框中。我从另一个项目中找到了代码,其他人在他们使用 Windows 窗体的地方创建了这些代码。我正在使用 vis
我是一名优秀的程序员,十分优秀!