首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >后台工作进程中的linq to sql查询无效的跨线程访问

后台工作进程中的linq to sql查询无效的跨线程访问
EN

Stack Overflow用户
提问于 2014-11-20 01:42:39
回答 1查看 340关注 0票数 0

这段代码抛出一个System.UnauthorizedAccessException: Invalid cross-thread access exception

代码语言:javascript
复制
private void DoWorker(object sender,DoWorkEventArgs e)
{
    BackgroundWorker worker = sender as BackgroundWorker;

    using (DbContext db = new DbContext(DbContext.littreConnectionString))
    {
        if (db.DatabaseExists())
        {
            var searchResults = from dbObject in db.LDicTable
                                where dbObject.word == SearchBox.Text
                                select dbObject;
            if (!searchResults.Any())
            {
                wordExists = false;
            }
        }
    }
}
EN

回答 1

Stack Overflow用户

发布于 2014-11-20 01:59:14

这是因为你不能在后台worker dowork方法中访问UI线程对象,因为它在单独的线程中执行,而不是在UI thread.so中,它在不同的线程中执行,而您试图访问UI线程对象。

您必须将文本框文本存储在某个字符串中,并在方法中使用该变量。

有关详细信息,请参阅以下链接:

http://www.codeproject.com/Questions/623667/BackGroundWorker-Thread-issue-with-UI-Thread

Why can't UI components be accessed from a backgroundworker?

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27023432

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档