gpt4 book ai didi

c# - 如何在 C# 中正确多线程运行时调用的 DLL

转载 作者:太空狗 更新时间:2023-10-30 01:24:49 25 4
gpt4 key购买 nike

全部,

我希望编写一个插件 .dll 以供运行时调用的 .NET 应用程序使用/调用。我的 .dll 是一个 WinForm 并显示正在执行的(计算量大的)操作。从主应用程序调用的 .dll 是通过 .NET System.Reflection 调用的。我必须向调用应用程序提供我要调用的 NameSpaceClassMethod

我想对我的 .dll 进行多线程处理,以便它对 UI 更友好,而且我只真正熟悉 BackgroundWorker

编辑:问题的扩展。

因此,我按如下方式调用 .dll:

if (classType != null)
{
if (bDllIsWinForm)
{
classInst = Activator.CreateInstance(classType);
Form dllWinForm = (Form)classInst;
dllWinForm.Show();

// Invoke required method.
MethodInfo methodInfo = classType.GetMethod(strMethodName);
if (methodInfo != null)
{
object result = null;
// The method being called in this example is 'XmlExport'.
result = methodInfo.Invoke(classInst, new object[] { dllParams });
return result.ToString();
}
}
else
{
// Else not a WinForm do simalar.
}
}

然后在 WinForm .dll 中,我想对耗时的工作进行多线程处理,以便我可以显示正在发生的事情。所以在 .dll 中,使用 BackgroundWorker 我有:

BackgroundWorker bgWorker; // Global.    

public string XmlExport(object[] connectionString)
{
try
{
bgWorker = new BackgroundWorker { WorkerReportsProgress = true, WorkerSupportsCancellation = true };
bgWorker.DoWork += new DoWorkEventHandler(bgWorker_DoWork);
bgWorker.ProgressChanged += new ProgressChangedEventHandler(bgWorker_ProgressChanged);
bgWorker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(bgWorker_RunWorkerCompleted);

// Wait until workerThread is done.
threadDoneEvent = new AutoResetEvent(false);
bgWorker.RunWorkerAsync();
threadDoneEvent.WaitOne();
return strResult; // Global String strResult
}
catch (Exception)
{
throw;
}
}

然后我有 DoWork 事件处理程序:

void bgWorker_DoWork(object sender, DoWorkEventArgs e)
{
BackgroundWorker thisWorker = sender as BackgroundWorker;
strResult = (string)this.XmlExportBgw(ref thisWorker); // Or should I use bgWorker?
e.Result = strResult;
}

public string XmlExportThreaded(ref BackgroundWorker thisWorker)
{
try
{
// Some expesive work...

// UI.
InfoBall infoBall = new InfoBall(); // Class containing processing information.
// Set infoBall parameters here...
(thisWorker as BackgroundWorker).ReportProgress(infoBall.progressBarValue, infoBall);

// Some more expensive work...

// UI.
(thisWorker as BackgroundWorker).ReportProgress(infoBall.progressBarValue, infoBall);
}
//...
}

`ProgressChanged' 事件是

void bgWorker_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
// UI.
InfoBall someBall = (InfoBall)e.UserState;

// Update process information.
if (someBall.showRichTextBox)
{
this.richTextBox.AppendText(someBall.richTextBoxText);
this.richTextBox.ScrollToCaret();
}
return;
}

除了上面的代码我还有通常的RunWorkerCompleted

已编写调用应用程序以允许用户在运行时调用自己的 .NET .dll。我试图放在一起的 .dll 是一个时间密集型的,并且只提供给特定用户。我已经运行了上面的代码,问题是它不会正确更新用户界面。也就是说,您无法操作(调整大小、单击等)Form,并且它不会打印和处理信息,直到处理结束时它才多次打印最终消息。但是,它正确地生成了我需要的 .xml 文件。我究竟做错了什么?我应该从单独的线程调用 .dll 方法吗?

如有任何帮助,我们将不胜感激。非常感谢您的宝贵时间。

最佳答案

我不确定您正在尝试在该 dll 中执行哪种方法。我假设它们不是异步的,这意味着您的主线程(应用程序)将停止,直到它们执行完毕。一个简单的例子可以用 Messagebox.show("myMessage"); 来演示。方法。例如,您如何一次执行 3 个消息框?不使用多线程是不可能的。希望这些方法有所帮助:

    public void SomeMethod()
{


Thread thread = new Thread(new ThreadStart(() =>
{
// this code is going to be executed in a separate thread
MessageBox.Show("hello");

// place additional code that you need to be executed on a separate thread in here

}));

thread.Start();
}

然后如果我调用该方法 3 次:

enter image description here

我现在将在我的程序上运行 4 个线程。主线程加上我创建的 3 个调用。

关于c# - 如何在 C# 中正确多线程运行时调用的 DLL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8352234/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com