- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我知道 C# 主程序的堆栈大小为 1 MB(32 位和任何)或 4 MB(64 位),请参阅 Why is stack size in C# exactly 1 MB?
BackgroundWorker
DoWork
线程的默认堆栈大小是多少?
有没有一种方法可以改变 BackgroundWorker
DoWork
线程的堆栈大小,同时创建另一个线程,如下例所示:
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
Thread thread = new Thread(delegate()
{
// do work with larger stack size
}, 8192 * 1024);
thread.Start();
thread.Join();
}
我正在使用 BackgroundWorker
,因为我有一个 Windows Forms
应用程序,我在其中的 DoWork
事件中进行一些计算。我这样做是因为我想向 GUI 的状态行报告,并且我希望用户可以取消计算。
我收到堆栈溢出错误,因为我正在调用英特尔 MKLs LAPACKE_dtrtri这是高度递归的,参见 http://www.netlib.org/lapack/explore-html/df/d5c/lapacke__dtrtri_8c_source.html .
以下代码展示了我如何调用 Intel MKL:
public static double[,] InvTriangularMatrix(double[,] a, bool isupper)
{
int n1 = a.GetLength(0);
int n2 = a.GetLength(1);
if (n1 != n2) throw new System.Exception("Matrix must be square");
double[,] b = Copy(a);
int matrix_layout = 101; // row-major arrays
char uplo = isupper ? 'U' : 'L';
char diag = 'N';
int lda = Math.Max(1, n1);
int info = _mkl.LAPACKE_dtrtri(matrix_layout, uplo, diag, n1, b, lda);
if (info > 0) throw new System.Exception("The " + info + "-th diagonal element of A is zero, A is singular, and the inversion could not be completed");
if (info < 0) throw new System.Exception("Parameter " + (-info) + " had an illegal value");
return b;
}
和
[DllImport(DLLName, CallingConvention = CallingConvention.Cdecl, ExactSpelling = true, SetLastError = false)]
internal static extern int LAPACKE_dtrtri(
int matrix_layout, char uplo, char diag, lapack_int n, [In, Out] double[,] a, int lda);
InvTriangularMatrix
在我的 DoWork
事件中调用。当我没有设置堆栈大小时,我在 LAPACKE_dtrtri
函数中遇到堆栈溢出错误。
矩阵的大小可以在 1000 x 1000 到 100000 x 100000 之间。如果矩阵大于 65535 x 65535,请参阅 2d-Array with more than 65535^2 elements --> Array dimensions exceeded supported range .
最佳答案
BackgroundWorker
DoWork
事件中的堆栈大小与主线程相同。
教授:
例如,将构建后事件中的堆栈大小设置为 8 MB:
"$(DevEnvDir)..\..\VC\bin\editbin.exe" /STACK:8388608 "$(TargetPath)"
然后使用以下代码请求堆栈大小:
[DllImport("kernel32.dll")]
internal static extern void GetCurrentThreadStackLimits(out uint lowLimit, out uint highLimit);
public static uint GetStackSize()
{
uint low, high;
GetCurrentThreadStackLimits(out low, out high);
return high - low;
}
在主程序和 DoWork
事件中使用 GetStackSize
在这两种情况下都会返回 8 MB 或您使用 EDITBIN/STACK
指定的任何内容。
关于c# - BackgroundWorker DoWork 线程的堆栈大小是多少?有办法改变吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56457637/
我使用的 BackgroundWorker 与以前有点不同。 通常,我使用 BW 来更新一些图形控件,我在 DoWork 方法中执行所有需要的任务,返回结果并为 RunWorkerCompleted
我正在尝试使用 WorkManager 中的 PeriodicWorkRequest 定期从远程 url 获取数据。我已经实现了逻辑,这里的问题是我没有从 Worker 得到任何响应。 但是它似乎在第
这个问题已经以不同的形式被问过很多次,但我没有回答正确,想知道它是否可能不是一个 android 错误。 设置 WorkManager 后,doWork() 会随机调用,有时会连续调用多达 10 次以
我正在寻找在后台线程中运行顺序子过程。我想知道是否可以这样做,方法是创建一个后台工作程序,然后像这样分别调用每个过程... Private Sub BGW_DoWork(ByVal sender As
我正在尝试使用 BackgroundWorker 来完成一项任务。我已经让 worker 正确运行,在 DoWork 方法下它然后调用另一个执行的方法但后来我遇到了我的问题:当该方法试图调用另一个方法
在下面的代码中,有没有一种方法可以不总是订阅 updateWorker_DoWork 方法,而是将它传递给这样的方法 public void GetUpdates(SomeObject blah) {
我正在编写一个基于表单的小型应用程序来连接到 LDAP 服务器,我希望“连接”按钮在后台工作。所以我关注信息和讨论 here 但无论出于何种原因,我的代码似乎都无法正常工作:我在“worker.Run
我正在尝试使用 WorkManager 进行服务器调用。所以,我写了下面的 Worker 类: class ServerCallWorker extends Worker { publ
我想计划任务在 24 小时后从数据库中删除 public class WorkManager extends Worker { public WorkManager(@NonNull Cont
我正在运行一个 BackgroundWorker 线程来完成一项耗时的任务。耗时的任务在另一个类(class)。我需要将在 BackgroundWorker 上运行的这个单独类所取得的进展传递回 Ma
我正在运行一个 BackgroundWorker 线程来完成一项耗时的任务。耗时的任务在另一个类(class)。我需要将在 BackgroundWorker 上运行的这个单独类所取得的进展传递回 Ma
我的问题如下: 我有一个窗口窗体,其中放置了一个 LayoutPanel,当窗体加载时,多个控件,如:文本框和标签被添加到 LayoutPanel。 然后单击按钮,我需要处理用户在那些动态创建的控件上
private void button_uploadToPI_Click(object sender, RoutedEventArgs e) { this.newFilePat
在 form1 之上 label5.Text = "00:00:00"; 在dowork事件中 private void backgroundWorker1_DoWork(object sender,
在我们基于 .NET Framework 的应用程序中,我们使用 BackgroundWorker 保存了一个巨大的文件保持 UI 响应。当我们关闭它时,我们不想停止后台工作(默认行为)并截断文件。
我正在使用后台工作程序来处理文件的加载以阻止我的用户界面卡住,但是似乎 RunWorkerCompleted 在我的 DoWork 事件发生之前完成已完成(退出对话框时导致错误)...我做错了什么吗?
假设我有一个 backgroundWorker1_DoWork,它在数据库中找到一个值并在 e.Result 中返回它。假设我还有一个读取结果的 backgroundWorker1_RunWorker
这是我的设置,这段代码可以正常工作 private void butGo_Click(object sender, EventArgs e) { threadCreateImages.RunWor
我知道 C# 主程序的堆栈大小为 1 MB(32 位和任何)或 4 MB(64 位),请参阅 Why is stack size in C# exactly 1 MB? BackgroundWorke
首先,我贴出我的代码: public partial class MainWindow : Window { private readonly BackgroundWorker worker
我是一名优秀的程序员,十分优秀!