草庐IT

线程不安全

全部标签

c# - wcf服务中的线程中止异常

我有一个托管在IIS6.0上的WCF服务(内置于.NETFramework3.5中)。代码流程如下客户端(这是另一个Web服务)调用WCF服务WCF服务调用一个线程在后台进行处理并立即响应被调用者。后台线程在完成所有处理后,回调线程。这个调用基本上是一个HTTPs请求,因为客户端是一个网络服务。我正在对我的WCF服务进行负载测试以定义阈值。观察结果如下:1分钟内向WCF服务发出的1024个请求的大约3次迭代成功通过。完成每次迭代所需的时间约为25-30分钟。然而,从第4次迭代开始,可以看到批量失败。大约50%的请求失败,但出现以下异常。Exception-Threadwasbeinga

c# - 哪些阻塞操作会导致 STA 线程发送 COM 消息?

当COM对象在STA线程上实例化时,该线程通常必须实现消息泵以编码来回其他线程的调用(请参阅here)。可以手动发送消息,也可以依靠一些但不是全部线程阻塞操作在等待时自动发送与COM相关的消息这一事实。文档通常无助于决定哪个是哪个(参见thisrelatedquestion)。如何确定线程阻塞操作是否会在STA上发送COM消息?到目前为止的部分列表:阻止做泵*的操作:Thread.JoinWaitHandle.WaitOne/WaitAny/WaitAll(虽然不能从STA线程调用WaitAll)GC.WaitForPendingFinalizersMonitor.Enter(因此lo

c# - 从多个线程进行单元测试的最佳方法是什么?

这种来自另一个question的后续我的。基本上,一旦我有了访问该文件的代码(稍后会查看那里的答案),测试它的最佳方法是什么?我正在考虑创建一个只产生大量BackgroundWorker的方法的或其他东西,并告诉他们所有加载/保存文件,并使用不同的文件/对象大小进行测试。然后,从线程获取响应以查看它是否失败/成功/是否使世界崩溃等。你们能就解决此问题的最佳方法提供任何建议吗?正如我之前所说,这对我来说有点新鲜:)编辑正在关注ajmastrean's帖子:我正在使用控制台应用程序通过Debug.Asserts进行测试:)更新我最初使用BackgroundWorker滚动处理线程(因为我已

c# - MemoryStream 有一个线程写入它,另一个线程读取它

这就是我写入流然后使用1个线程从中读取的方式:System.IO.MemoryStreamms=newSystem.IO.MemoryStream();//writetoitms.Write(newbyte[]{1,2,3,4,5,6,7},0,7);//gotothebeginingms.Seek(0,System.IO.SeekOrigin.Begin);//nowreadfromitbyte[]myBuffer=newbyte[7];ms.Read(myBuffer,0,7);现在我想知道是否可以从一个线程写入内存流并从另一个线程读取该流。 最佳答案

c# - 与 MTA 线程相比,STA 线程有哪些限制?

如果我们像这样创建一个线程STA:Thread.SetApartmentState(STA);那么它就不能运行用[MTAThread]属性标记的代码。我们已经在Windows和控制台应用程序中看到了[STAThread],但我从未见过带有[MTAThread]属性的代码,也不知道哪些.NET库使用了它属性。我的问题是,与具有MTA单元状态的线程(自然.NET线程)相比,单元状态设置为STA的线程有什么限制? 最佳答案 thenitcannotruncodemarkedwith[MTAThread]attribute.这不是它的工作原

c# - 如何命名运行任务的线程?

我发现命名线程在调试时非常有用。我看不出有什么方法可以使用Task.Factory.StartNew()的参数来命名线程那么在任务中显式命名线程是否可以接受?例如:privatevoidMyFunc(){Task.Factory.StartNew(()=>{Thread.CurrentThread.Name="Foobulizer";Foobulize();});}但是,我很欣赏线程可能会被不同的任务重用,所以我是否需要在任务结束时显式地重置线程名称?这感觉很老套,所以我认为这可能是个坏主意,或者有正确的方法来做到这一点? 最佳答案

c# - 启动多个线程并从我的 .NET 应用程序中跟踪它们

我想从我的.NET应用程序启动x个线程,并且我想跟踪它们,因为我需要手动终止它们,或者当我的应用程序稍后关闭我的应用程序时。示例==>StartThreadAlpha,StartThreadBeta..然后在我的应用程序中的任何时候我都应该能够说TerminateThreadBeta..在.NET中跟踪打开的线程的最佳方法是什么?我需要了解有关终止线程的哪些信息(ID?)? 最佳答案 你可以节省自己的驴子工作并使用这个SmartThreadPool。它提供了一个工作单元系统,允许您随时查询每个线程的状态,并终止它们。如果这太麻烦了,

在自己的线程中执行的线程之间的 C# 事件(如何)?

我想要两个线程。我们称他们为:线程A线程B线程A触发一个事件,线程B监听这个事件。当线程B事件监听器被执行时,它是用线程A的线程ID执行的,所以我猜它是在线程A中执行的。我想做的是能够向线程B触发事件,说类似这样的话:“嘿,数据已经为您准备好了,您现在可以处理它了”。这个事件必须在它自己的线程中执行,因为它使用只有他可以访问的东西(比如UI控件)。我该怎么做?谢谢你的帮助。 最佳答案 您需要将信息编码回UI线程。通常,您会在事件处理程序中处理它。例如,假设线程A是您的UI线程-当它订阅线程B中的对象上的事件时,事件处理程序将在线程B

c# - 如何中止使用 ThreadPool.QueueUserWorkItem 创建的线程

有没有办法中止使用QueueUserWorkItem创建的线程?或者也许我不需要?如果主应用程序退出会怎样?所有从它创建的线程都自动中止了吗? 最佳答案 您不需要中止它们。当您的应用程序退出时,.NET将终止所有IsBackground=true的线程。.NET线程池的所有线程都设置为IsBackground=true,因此您不必担心。现在,如果您通过更新Thread类来创建线程,那么您需要中止它们或将它们的IsBackground属性设置为true。 关于c#-如何中止使用Thread

【多线程进阶】锁策略和CAS面试题

🎉🎉🎉点进来你就是我的人了博主主页:🙈🙈🙈戳一戳,欢迎大佬指点!欢迎志同道合的朋友一起加油喔🦾🦾🦾​​​​​​​目录1.乐观锁vs悲观锁1.1悲观锁1.2乐观锁2.重量级锁vs轻量级锁2.1轻量级锁2.2重量级锁3.自旋锁VS挂起等待锁3.1自旋锁3.2 挂起等待锁4.互斥锁VS读写锁4.1互斥锁4.2读写锁5.可重入锁VS不可重入锁5.1可重入锁5.2不可重入锁6.CAS6.1实现原子类:6.2实现自旋锁:7.面试题,CAS的ABA问题怎么解决1.乐观锁vs悲观锁Java中的乐观锁和悲观锁是两种并发控制的策略,用于解决多线程访问共享资源时可能出现的竞争和冲突问题。1.1悲观锁悲观锁的思想是,