WPF剪切板问题-OpenClipboard HRESULT:0x800401D0 (CLIPBRD_E_CANT_OPEN))

博客探讨了在WPF应用中遇到的OpenClipboard错误,异常代码为HRESULT:0x800401D0 (CLIPBRD_E_CANT_OPEN),并提出了自行截获并处理此类异常的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

WPF剪切板问题-OpenClipboard HRESULT:0x800401D0 (CLIPBRD_E_CANT_OPEN))


 
    最近碰到一个问题,需要弄个小工具来解决。刚好接触到WPF,于是就想通过WPF来实现。
    在这个过程中想通过程序将一些东西复制到剪切板中,代码很简单:Clipboard.SetText(lineTexts[lineIndex]);就这一句,想把lineTexts这个字符串List中的第lineIndex项复制到剪切板中,但是运行的时候就会抛出异常,大致的异常信息是“OpenClipboard HRESULT:0x800401D0 (CLIPBRD_E_CANT_OPEN))”(挺长的一段,注意没写全)。而winform那边之前也用过,没有问题。
    上网搜索了一下,看了挺多资料,发现是WPF本身对Clipboard处理的问题,在.Net4.0及之前的版本中都有问题,最近Micorsoft已经在.Net4.5中修复了。问题主要是由于:在程序访问剪切板的时候,有其他程序正在占用剪切板,导致自己的程序无法访问,从而抛出异常。
    在.Net4.0上,解决这个问题,我大概总结了一下,有下面几种方法:
  1. 自行截获异常,进行处理
         for (int i = 0; i < 10; i++)
         {
              try
              {
                   Clipboard.SetText(lineTexts[lineIndex]);
                   break;
              }
              catch
              {
                   System.Threading.Thread.Sleep(10);//这句加不加都没关系
              }
          }

 


        这种方法处理过程中UI会有一小段时间的假死。。。可以考虑多线程?

   2. 换一种方式设置剪切板
          Clipboard.SetDataObject(lineTexts[lineIndex]);
        就这一句。。。这种方法不会抛异常,UI也没有假死,非常正常!估计SetDataObject方法跟SetText方法的实现不一样,没有细究。。。

   3. 跟方法1类似,不过有点高级
剪切板处理的那句代码不变,还是使用SetText方法。
    在App.xaml文件中添加下面代码中红色的部分

            xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
            xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             StartupUri="MainWindow.xaml"
             DispatcherUnhandledException="Application_DispatcherUnhandledException">
   
        
   

          在App.xaml.cs文件中添加代码:
void Application_DispatcherUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e)
{
      var comException = e.Exception as System.Runtime.InteropServices.COMException;
      if (comException != null && comException.ErrorCode == -2147221040)///OpenClipboard HRESULT:0x800401D0 (CLIPBRD_E_CANT_OPEN))
          e.Handled = true;
}
这种方法中剪切板动作会自动多次尝试,由于抛出的异常被App中的异常处理给截获了,所以会不断的尝试直到成功。方法三也有一定程度的UI假死。对于方法三,具体原理可以到MSDN上搜一下DispatcherUnhandledException或相关内容,这里一时半会说不清楚。
方法三使用范围广,可以类似的处理其他的异常。而方法二只能是自己的代码才能解决,如果用到WPF控件或者其他第三方控件就不行了。所以推荐方法三,但如果是自己写的代码,用方法二就简单方便的多。
wpf 试图加载格式不正确的程序。 (异常来自 HRESULT:0x8007000B)错误通常在C#调用C dll时出现,有几种可能的原因和解决方法。 首先,这个错误可能是由于程序的运行平台系统位数不匹配导致的。比如,如果在64位系统上,C#调用32位的C dll,就会出现这个错误。解决这个问题的方法是,在VS中将生成的目标平台设为X86。具体的操作是,在项目的属性窗口中选择"生成",然后再选择"目标平台",将其设置为"X86"。这样就可以解决这个错误。 其次,这个错误也可能是由于VS设置的问题导致的。如果前面的方法无效,可以尝试打开对应的工程文件(*.csproj),找到<Prefer32Bit>false</Prefer32Bit>节点,将其改为<Prefer32Bit>true</Prefer32Bit>。这样也可以解决这个错误。 最后,如果以上方法都没有解决问题,那可能是因为客户端平台不允许修改。此时,可以选择使用AnyCPU平台,并勾选首选32位选项解决这个问题。 总结来说,当出现wpf 试图加载格式不正确的程序。 (异常来自 HRESULT:0x8007000B)错误时,可以尝试以下解决方法:确保C#调用的C dll与运行的平台系统位数匹配,设置生成的目标平台为X86,修改工程文件中的<Prefer32Bit>节点,或选择使用AnyCPU平台并勾选首选32位选项。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [C# 试图加载格式不正确的程序。 (异常来自 HRESULT:0x8007000B)](https://blog.youkuaiyun.com/liangyj66/article/details/70569953)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [试图加载格式不正确的程序。 (异常来自 HRESULT:0x8007000B)](https://blog.youkuaiyun.com/s_156/article/details/120632575)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

过客非归

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值