草庐IT

thread-safety

全部标签

c# - System.Threading.Tasks 中的 NullReferenceException 调用 HttpClient.GetAsync(url)

我的MVC4.0应用程序有一个奇怪的问题。我使用REST网络服务(AmazonAssociate)。我创建了一种方法,可以在任何地方使用。缩短版是这样的:privateasyncTaskGetRequest(stringurl){stringmyresponse;HttpResponseMessageresponse=null;HttpClientclient=newHttpClient();try{response=awaitclient.GetAsync(url);myresponse=response.Content.ToString();if(myresponse.Contai

c# - 并发集合在没有 Thread.Sleep 的情况下吃太多 cpu

BlockingCollection或ConcurrentQueue的正确用法是什么,这样您就可以自由地使项目出队,而不会使用线程消耗一半或更多的CPU?我正在使用2个线程运行一些测试,除非我有至少50~100毫秒的Thread.Sleep,否则它总是会占用至少50%的CPU。这是一个虚构的例子:privatevoid_DequeueItem(){objecto=null;while(socket.Connected){while(!listOfQueueItems.IsEmpty){if(listOfQueueItems.TryDequeue(outo)){//usethedata}

c# - 未经授权的访问异常 : Invalid cross-thread access in Silverlight application (XAML/C#)

C#相对较新,想尝试使用它来使用一些第三方Web服务API。这是XAML代码这是C#代码privatevoidButton_Click(objectsender,RoutedEventArgse){HttpWebRequestrequest=(HttpWebRequest)WebRequest.Create("http://api.twitter.com/1/users/show/keykoo.xml");request.Method="GET";request.BeginGetResponse(newAsyncCallback(twitterCallback),request);}p

c# - 将锁与 Threading.Timer 一起使用

我有一个Windows服务应用程序,它使用Threading.Timer和TimerCallback在特定时间间隔进行一些处理。我需要一次将此处理代码锁定到1个线程。因此,例如,启动服务并触发第一个回调,然后启动一个线程并开始处理。只要处理在下一次回调之前完成,这就可以正常工作。例如,处理时间比平时稍长,并且在另一个线程正在处理时再次触发TimerCallback,我需要让该线程等待另一个线程完成。这是我的代码示例:staticTimertimer;staticobjectlocker=newobject();publicvoidStart(){varcallback=newTimer

c# - c#中的方法锁

我有一节课使用这三种方法。这个类被许多线程使用。如果Method2和/或Method3在任何线程中运行,我希望Method1等待。有什么建议吗?publicclassClass1{publicstaticvoidMethod1(){ObjectlockThis=newObject();lock(lockThis){//Bodyfunction}}publicstaticvoidMethod2(){//Bodyfunction}publicstaticvoidMethod3(){//Bodyfunction}} 最佳答案 如果我没理解

c# - Thread.Sleep(timeout) 和 ManualResetEvent.Wait(timeout) 有什么区别?

Thread.Sleep(timeout)和resetEvent.Wait(timeout)都会导致执行暂停至少timeout毫秒,那么它们之间有区别吗?我知道Thread.Sleep导致线程放弃其时间片的剩余部分,因此可能导致sleep持续时间比请求的时间长得多。ManualResetEvent对象的Wait(timeout)方法是否有同样的问题?编辑:我知道ManualResetEvent的要点是从另一个线程发出信号-现在我只关心事件的Wait方法指定超时的情况,并且没有其他来电者设置事件。我想知道按时唤醒是否比Thread.Sleep更可靠 最佳答案

c# - 检测一个方法在没有锁的情况下被调用

有什么方法可以检测到我的代码中的某个方法被调用,而无需在调用堆栈中的以下任何方法中使用任何锁?目标是调试有故障的应用程序并查明某些代码段是否不是线程安全的。 最佳答案 这似乎是AOP(面向方面​​的编程)的一个不错的用例。AOP的一个非常基本的总结是,它是一种处理横切关注点的方法,使代码干燥和模块化。这个想法是,如果你对一个对象的每个方法调用做一些事情(例如记录每个调用)而不是在每个方法的开始和结束添加日志,你而是继承对象并在类之外做为了不混淆其目的。这可以通过几种方式完成,我将举两个例子。首先是手动(这不是很好,但对于小箱子可以很

c# - 如何通过缓存键锁定?

我正在尝试实现一个通用的线程安全缓存方法,我想知道我应该如何在其中实现锁。它应该看起来像这样://privatestaticreadonlylockObject=newObject();publicTGetCache(stringkey,FuncvalueFactory...){//trytopullfromcacheherelock(lockObject)//Idon'twanttousestaticobjectlockherebecausetheneverytimealockisperformed,allcachedobjectsinmysitehavetowait,regardi

c# - 预定义类型 'System.Threading.Tasks.Task' 在全局别名的多个程序集中定义

我刚刚建立了一个新的asp.netmvc4项目,结合使用最新的.net框架(4.5)和VisualStudio2012。在我添加了一些类、辅助项目等之后。我突然注意到我编译项目时收到5次相同的警告。警告指出:ASPNETCOMPILER:warningCS1685:Thepredefinedtype'System.Threading.Tasks.Task'isdefinedinmultipleassembliesintheglobalalias;usingdefinitionfrom'c:\ProgramFiles(x86)\ReferenceAssemblies\Microsoft\

c# - 在返回 IEnumerable 的方法中使用锁时,linq 延迟执行

考虑一个由多个线程访问的简单Registry类:publicclassRegistry{protectedreadonlyDictionary_items=newDictionary();protectedreadonlyobject_lock=newobject();publicvoidRegister(intid,stringval){lock(_lock){_items.Add(id,val);}}publicIEnumerableIds{get{lock(_lock){return_items.Keys;}}}}和典型用法:varids1=_registry.Ids;//exe