草庐IT

timer_handle

全部标签

c# - 我可以将匿名函数绑定(bind)到 Timer 的滴答事件吗?

如果Tick-handling函数只会在一个上下文中使用(即总是在同一个函数中与同一个Timer对象结合使用),为什么还要将它作为一个单独的函数呢?当我想到这个时,这就是我脑海中闪过的想法。是否可以将匿名函数与Timer的滴答事件关联起来?这就是我想要做的。TimermyTimer=newTimer();myTimer.Tick+=newEventHandler(function(objectsender,EventArgse){MessageBox.Show("Helloworld!");}); 最佳答案 您正在寻找Anonymo

c# - 奇怪的 handle 泄漏

我的应用程序(基本应用程序是与C++/CLI互操作的MFC,但它还包含大量C#、Windows窗体、WPF)有句柄泄漏。应用程序启动后不久,我可以看到任务管理器中的句柄数持续增长(以每秒10个新句柄的速度)。所以我用了handles.exe看看它们是什么类型的句柄。我发现泄漏的句柄是进程句柄。它们是我的应用程序进程的进程句柄。所以我想知道哪些操作通常会为其运行的进程创建句柄。有什么想法吗?你见过这样的事吗?考虑到我不能使用调试DLL并且我只能使用可以xcopy部署的工具,我还能做些什么来追踪泄漏。更新:我能够向它抛出windbg和!handle,!htrace并发现进程句柄都是使用以下

c# - 单元测试 system.timers.timer

我一直在阅读有关使用计时器和线程进行单元测试的问题。我发现了有关单元测试system.threading.timers的SO问题,但我需要对system.timers.timer进行单元测试,而包装类似乎无法正常工作。我只需要知道如何模拟计时器和/或系统时间,以便对其进行单元测试。我似乎无法在谷歌上的任何地方找到这个。编辑和更新:这是有道理的,如果我通过如下包装提取计时器,我可以生成一个计时器并使用模拟将其替换为不同的计时器。相关的部分是获取我在运行时注入(inject)的计时器(原始的,而不是模拟的)并测试它的已用事件代码。 最佳答案

c# - 使 System.Threading.Timer 无效会停止吗?

如果我有一个活跃的System.Threading.Timer我将它设置为null,它停止了吗?我意识到调用.Dispose()更合适,但我想要问题的答案。publicclassFoo{privateSystem.Threading.Timer_timer;publicFoo(){//initializetimer}publicvoidKillTimer(){_timer=null;}}更新:经过反复讨论是否将对System.Threading.Timer的单个引用设置为null确实会导致停止它表明没有挥之不去的引用,例如事件列表,因为线程计时器接受单一回调并且不公开事件。如果GC收集

c# - 有什么理由让 Timer 将 AutoReset 设置为 false,然后在其经过的事件期间重新启动自身?

我刚碰到这段代码,但我不明白。是否有理由使用这种设计,而不是仅在AutoReset为true的情况下重新运行经过的代码?privatereadonlyTimerTimer=newTimer();protectedoverridevoidOnStart(string[]args){Logger.InfoFormat("Starting{0}.",ServiceName);try{//IfEnabledissettotrueandAutoResetissettofalse,theTimerraisestheElapsedeventonlyonce,thefirsttimetheinterv

⌈C⌋哈希表UT_hash_handle——如何将结构体类型作为key

目录前言一、创建结构体二、定义哈希表指针三、函数操作1.HASH_ADD2.HASH_FIND四、运用剑指Offer52. 两个链表的第一个公共节点 两数之和692. 前K个高频单词前言很早之前,在我刷leetcode的时候遇见使用哈希表的题目,我怀着好奇心去搜索,发现C语言可以用数组简单模拟(但是key值超过数组最大范围那就不行了),但是写了一篇关于简单哈希表运用的文章 数组模拟哈希表的简单运用https://blog.csdn.net/Dusong_/article/details/127257647?spm=1001.2014.3001.5502但是用数组仅限于key为整型(int),但

c# - 为什么System.Timers.Timer.Interval 的数据类型是double?

这是一个有点学术性的问题,因为我正在努力思考Microsoft使用double作为Interval属性的数据类型背后的想法!首先来自MDSNInterval是Elapsed事件之间的时间,以毫秒为单位;我会将其解释为离散数字,那么为什么要使用double呢?肯定int或long更有意义!?Interval可以支持5.768585(5.768585毫秒)这样的值吗?尤其是当人们认为System.Timers.Timer的精度远不及亚毫秒时...Mostaccuratetimerin.NET?对我来说似乎有点愚蠢..也许我错过了什么! 最佳答案

c# - Timer.Change() 会返回 false 吗?

.NETSystem.ThreadingTimer类有几个重载的Change()方法,这些方法返回“如果计时器已成功更新,则返回true;否则返回false。”引用:http://msdn.microsoft.com/en-us/library/yz1c7148.aspx这个方法真的会返回false吗?什么会导致它返回false? 最佳答案 JoeDuffy(Parallel的开发负责人、架构师和创始人Microsoft的.NETFramework团队的扩展)详见Windows上的并发编程p373NotethatalthoughCh

c# - 诊断 ObjectDisposedException "Safe handle has been closed"

我有一个C#应用程序,它正在使用消息命中ObjectDisposedExceptionSafehandlehasbeenclosed我一启动应用程序就会发生这种情况。遗憾的是,堆栈跟踪确实没有帮助(见下文)。我有什么办法可以确定这里正在异步尝试调用什么?DoAsyncCall()真的意味着异步方法调用吗?mscorlib.dll!System.Threading.EventWaitHandle.Set()+0xebytesmscorlib.dll!System.Runtime.Remoting.Messaging.AsyncResult.SyncProcessMessage(Syste

c# - 将异步回调传递给 Timer 构造函数

我有异步回调,它被传递到Timer(来自System.Threading)构造函数:privateasyncTaskHandleTimerCallback(objectstate){if(timer==null)return;if(asynTaskCallback!=null){awaitHandleAsyncTaskTimerCallback(state);}else{HandleSyncTimerCallback(state);}}和计时器:timer=newTimer(asynco=>awaitHandleTimerCallback(o),state,CommonConstant