草庐IT

C++11多线程—thread

全部标签

c# - 只读 HashSet 本身是线程安全的吗?

如果我初始化一个HashSet在Lazy里面初始化程序,然后从不更改内容,是HashSet本质上是线程安全的?是否有需要锁定的读取操作?类似的Java问题here对于一般的集合,这基本上是肯定的,但有一些警告(不适用于这种情况)。 最佳答案 是的,是的。只要施工了HashSet对象是线程安全的,只要内容不变,访问它就始终是线程安全的。如果你initializeLazy使用LazyThreadSafetyMode.PublicationOnly你可以确定Lazy的初始化是线程安全的。Whenmultiplethreadstrytoin

c# - 在 HashSet<T> 中是否包含线程安全

查看Contains的代码在HashSet.NET源代码中的类,我找不到任何原因Contains不是线程安全的吗?我正在加载HashSet提前使用值,然后检查Contains在多线程中。AsParallel()循环。这有什么不安全的原因吗?我不愿意使用ConcurrentDictionary当我实际上不需要存储值时。 最佳答案 通常(通常)仅用于读取的集合是“非官方”线程安全的(我知道.NET中没有任何集合在读取期间会自行修改).有一些注意事项:项目本身可能不是线程安全的(但对于HashSet,这个问题应该被最小化,因为你不能从中提

c# - 如何测试线程是否持有 C# 中的对象锁?

有没有办法测试当前线程是否持有对象的监视器锁?IE。相当于Java中的Thread.holdsLock。谢谢, 最佳答案 我不相信有。你可以做一些很糟糕的事情,比如调用Monitor.Wait(monitor,0)并捕获SynchronizationLockException,但这非常可怕(理论上可以“捕获”一个脉冲另一个线程正在等待)。恐怕我建议您尝试重新设计,这样您就不需要它了。编辑:在.NET4.5中,这可用于Monitor.IsEntered. 关于c#-如何测试线程是否持有C#

c# - 如何取消阻塞已调用 AutoResetEvent 对象上的 WaitOne 方法的线程?

下面是一个具有方法“SomeMethod”的类,它说明了我的问题。classSomeClass{AutoResetEventtheEvent=newAutoResetEvent(false);//morememberdeclarationspublicvoidSomeMethod(){//somecodetheEvent.WaitOne();//morecode}}该方法被设计成线程安全的,会在不同的线程中被调用。现在我的问题是,如何才能取消阻塞在任何时间点对“theEvent”对象调用“WaitOne”方法的所有线程?这个需求在我的设计中经常出现,因为我需要能够优雅地停止和启动我的多

c# - AutoMapper——继承映射不​​工作,相同的源,多个目的地

我可以在AutoMapper(v2.2)中对源类型相同但目标类型不同的映射使用继承映射吗?我有这样的基本情况(真正的类有更多的属性):publicabstractclassBaseViewModel{publicintCommonProperty{get;set;}}publicclassViewModelA:BaseViewModel{publicintPropertyA{get;set;}}publicclassViewModelB:BaseViewModel{publicintPropertyB{get;set;}}ViewModelA和ViewModelB是同一实体类的不同表示

c# - 在 C# 中是否应该始终保留对正在运行的 Thread 对象的引用?

或者可以这样做吗:newThread(newThreadStart(delegate{DoSomething();})).Start();?我似乎记得在这种情况下,Thread对象会被垃圾回收,但底层操作系统线程会继续运行,直到传递给它的委托(delegate)结束。我基本上是在寻找ThreadPool功能,但不希望线程成为后台线程(即我希望它们使应用程序保持事件状态)。更新:根据Jason的说法,CLR在运行时实际上保留了对Thread对象的内部引用,因此在线程退出之前不会对其进行垃圾回收。 最佳答案 我一般发现,如果我需要像你例

c# - C# 中的线程和静态方法

这里以一个无意义的扩展方法为例:publicstaticclassMyExtensions{publicstaticintMyExtensionMethod(thisMyTypee){intx=1;x=2;returnx}}假设一个执行线程完成并包括以下行:x=2;处理器然后上下文切换,另一个线程进入相同的方法并完成该行:intx=1;我是否正确地假设第一个线程创建和分配的变量“x”与第二个线程创建和分配的变量“x”位于单独的堆栈上,这意味着该方法是可重入的? 最佳答案 是的,每个线程都有自己独立的局部变量。即使被多个线程同时调用,

c# - nHibernate session 和多线程

我有一个方法有很多使用nHibernatesession的持久性调用,它有效,没问题。但出于多线程原因,我需要重构此方法,从循环内的内容中提取方法。然后我用这个方法创建了一个类。这就像一个正常的重构,但是这个方法调用中的nHibernatesession被破坏了,没有上下文,我没有在任何时候完成它。nHibernate是否存在多线程问题?即使我只执行一个线程,我也会遇到同样的问题。我通过SessionFactory和Façade模式使用nHibernateSession,这意味着,session不是这些对象的字段,它在SessionFactory中是全局的。让它更清晰一点:之前:Met

C# 2.0 线程问题(匿名方法)

我有一个包含以下代码的简单应用程序:FileInfo[]files=(newDirectoryInfo(initialDirectory)).GetFiles();Listthreads=newList(files.Length);foreach(FileInfofinfiles){Threadt=newThread(delegate(){Console.WriteLine(f.FullName);});threads.Add(t);}foreach(Threadtinthreads)t.Start();假设在“I=initialDirectory”目录中我有3个文件。然后这个应用程序

c# - 多线程 C# 应用程序中的惰性单例

我正在开发一个使用WCFWeb服务的多线程C#应用程序。与web服务的连接将有一个特定的超时时间,我们可以定义该超时时间,超时后它将关闭。我希望使用单例类来存储与Web服务的连接。我正在尝试按如下方式获取实例:CLazySingletonins=CLazySingleton.Instance;stringconnection=CLazySingleton.abc;下面是单例类的代码:usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Text;namespaceLazySingleton{pu