BeginInvoke抛出exception

我有以下问题。 FindRoot实际上是在第三方dll中,我无法控制它。 它必须通过Begin调用来调用 。 有时,FindRoot方法会抛出exception。 这导致我的整个应用程序崩溃。 现在,即使FindRoot抛出exception,我如何防止我的应用程序崩溃。 delegate void AddRoot(double number); public static void FindRoot(double number) { throw new Exception();/// sometimes is thrown. } static void back_DoWork(object sender, DoWorkEventArgs e) { AddRoot root = FindRoot; root.BeginInvoke(12.0, root.EndInvoke, root); }

如何在WPF中处理Canvas.Top更改事件?

我在Canvas使用附加属性Canvas.Top和Canvas.Left定位了一个元素。 然后使用动画将元素移动到不同的坐标集,如下所示: DoubleAnimation left = new DoubleAnimation( oldLeft, newLeft ); DoubleAnimation top = new DoubleAnimation( oldTop, newTop ); element.BeginAnimation( Canvas.LeftProperty, left ); element.BeginAnimation( Canvas.TopProperty, top ); 有没有办法在Canvas.Top或Canvas.Left被更改时接收事件? 优选地与动画无关。

我如何实现IEnumerable?

我有一个包含静态对象数的类。 需要经常将此类与其他将成为简单List对象的类进行“比较”。 public partial class Sheet { public Item X{ get; set; } public Item Y{ get; set; } public Item Z{ get; set; } } 这些项目显然不会是“X”“Y”“Z”,这些只是通用名称。 问题在于,由于需要做的事情的性质,列表不起作用; 即使这里的所有东西都是Item类型。 它就像一个非常具体的事项清单,必须在代码和运行时进行测试。 这一切都很好,很好; 这不是我的问题。 我的问题是迭代它。 例如,我想做以下事情…… List UncheckedItems = // Repository Logic Here. UncheckedItems包含所有可用项目; CheckedItems是Sheet类实例。 CheckedItems将包含从Unchecked移动到Checked的项目; 但是由于存储系统的性质,移动到“已检查”的项目无法从“未选中”中删除。 我只想迭代“已检查”并从“已检查”中的已取消选中的列表中删除任何内容。 所以很自然地,这将是一个普通的列表。 foreach(Item item in Unchecked) { if( Checked.Contains(item) ) […]

从给定的线程获取SynchronizationContext

我似乎没有找到如何获取给定Thread的SynchronizationContext : Thread uiThread = UIConfiguration.UIThread; SynchronizationContext context = uiThread.Huh?; 我为什么需要那个? 因为我需要从前端应用程序的不同位置发布到UIThread。 所以我在名为UIConfiguration的类中定义了一个静态属性。 我在Program.Main方法中设置了这个属性: UIConfiguration.UIThread = Thread.CurrentThread; 在那一刻我可以肯定我有正确的线程,但是我不能设置像这样的静态属性 UIConfiguration.SynchronizationContext = SynchronizationContext.Current 因为尚未安装该类的WinForms实现。 由于每个线程都有自己的SynchronizationContext,因此必须可以从给定的Thread对象中检索它,否则我完全错了?

复制Word doc的内容并粘贴到另一个

我如何以编程方式复制一个word文档的内容并使用C#将其粘贴到另一个word文档? 我基本上想要复制个人资料(这是一个单词doc的内容),然后将其插入报告中。 任何帮助将不胜感激 谢谢

异步友好的DispatcherTimer包装器/子类

我在我的代码中运行一个DispatcherTimer ,每30秒触发一次,从服务器更新系统状态。 即使我正在调试我的服务器代码,计时器也会在客户端中触发,所以如果我已经调试了5分钟,我可能会在客户端中进行十几次超时。 最后决定我需要解决这个问题,以便制作一个更加async / await友好的DispatcherTimer。 在DispatcherTimer运行的代码必须是可配置的,无论它是否是可重入的(即,如果任务已在运行,则不应尝试再次运行它) 应该是基于任务的(这是否需要我实际上在根处公开Task是一个灰色区域) 应该能够运行异步代码并await任务完成 无论是包装还是扩展DispatcherTimer可能并不重要,但如果您不知道如何使用它,包装它可能会稍微不那么模糊 可能为UI的IsRunning公开可绑定属性

Double.MaxValue到整数是否定的?

为什么Double.MaxValue转换为整数类型会导致负值,该类型的最小值? double maxDouble = double.MaxValue; // 1.7976931348623157E+308 long maxDoubleLong = (long) maxDouble; // -9223372036854775808 我理解编译器错误,如果它太大或运行时出现OverflowException ,或者如果我使用unchecked ,转换可能不会引发exception,但结果将变为未定义且不正确(否定)。 同样奇怪的是值很长long.MinValue : bool sameAsLongMin = maxDoubleLong == long.MinValue; // true 顺便说一句,如果我将它转换为int也会发生同样的情况: int maxDoubleInt = (int)maxDouble; // -2147483648 bool sameAsIntMin = maxDoubleInt == int.MinValue; // true 如果它试图将其强制转换为decimal我会在运行时获得一个OverflowException decimal maxDoubleDec = (decimal)maxDouble; // nope 更新 :看起来迈克尔和巴雷的答案在头上很明显,如果我明确地使用了checked我会得到一个OverflowException : checked { double […]

如何删除其他进程正在使用的文件?

当我尝试删除文件时发生以下exception: 该进程无法访问该文件,因为它正由另一个进程使用。 我的代码看起来像: string[] files = Directory.GetFiles(@”C:\SEDocumentConverter\SOURCE”); foreach (string file in files) { File.Delete(file); } 我怎么解决这个问题?

在Silverlight的扩展方法中使用reflection进行深层复制?

所以我试图找到一个通用的扩展方法,它使用reflection创建一个对象的深层副本,可以在Silverlight中使用。 使用序列化的深层复制在Silverlight中并不是那么好,因为它以部分信任方式运行并且BinaryFormatter不存在。 我也知道,reflection会比克隆序列化更快。 有一个方法可以复制公共,私有和受保护的字段,并且是递归的,这样它就可以复制对象中的对象,并且还可以处理集合,数组等。 我在线搜索,只能使用reflection找到浅拷贝实现。 我不明白为什么,因为你可以使用MemberwiseClone,所以对我来说,这些实现是没用的。 谢谢。

如何最小化/最大化打开的应用程序

我有打开的应用程序列表。 要获得此列表,我使用了以下代码 internal static class NativeMethods { public static readonly Int32 GWL_STYLE = -16; public static readonly UInt64 WS_VISIBLE = 0x10000000L; public static readonly UInt64 WS_BORDER = 0x00800000L; public static readonly UInt64 DESIRED_WS = WS_BORDER | WS_VISIBLE; public delegate Boolean EnumWindowsCallback(IntPtr hwnd, Int32 lParam); public static List GetAllWindows() { List windows = new List(); StringBuilder […]