频繁读写剪贴板导致操作失败的bug

简介:

在家里的xp上装了SQL Server 2005,当在管理器里面出现错误信息提示窗口时,我们会发现这个窗口和Windows经典的Alert窗口有所不同,它增加了两个按钮。一个是复制错误信息,一个是查看错误详细信息。本来是很贴心的功能,没想到却出了问题,当我频繁点击Copy按钮后,系统就会出一个操作Clipboard的异常,详细信息如图:

    SQL Server 2005的管理抛出的错误提示窗口:
    SQL.2005.MsgBox.png

    异常详细信息如下:
    SQL.2005.AdvInfo.png

    频繁点击Copy(第一个)按钮,就会出以下异常:
    SQL.2005.MsgBox2.png

===================================
This message cannot be copied to the clipboard. (Microsoft SQL Server Management Studio)
===================================

Requested Clipboard operation did not succeed. (System.Windows.Forms)
------------------------------
Program Location:

   at System.Windows.Forms.Clipboard.ThrowIfFailed(Int32 hr)
   at System.Windows.Forms.Clipboard.SetDataObject(Object data
, Boolean copy, Int32 retryTimes,  Int32 retryDelay)
   at System.Windows.Forms.Clipboard.SetDataObject(Object data,
 Boolean copy)
   at Microsoft.NetEnterpriseServers.AdvancedInformation.CopyToClipboard()

    这其实不是一个必然bug,我在公司的windows 2003上就无法复现,它和系统的状态有比较密切的关系。那么我们怎么在我们自己的程序中避免出现这样的问题呢?只是胡乱的try掉这个调用吗?

    从上面的异常信息堆栈中,我们可以看到.NET Framework 2.0为我们操作剪贴板提供了一个新的重载:
    System.Windows.Forms.Clipboard.SetDataObject(Object data, Boolean copy, Int32 retryTimes, Int32 retryDelay)

    看来微软虽然看到了操作剪贴板具有不稳定性,结果却还是没有能完美的解决。


本文转自博客园鸟食轩的博客,原文链接:http://www.cnblogs.com/birdshome/,如需转载请自行联系原博主。

目录
相关文章
|
2月前
|
机器学习/深度学习 存储 缓存
【CVDEBUG-1】- 页面文件太小,无法完成操作怎么办
在执行深度学习任务时,尤其是YOLO训练过程中,可能会遇到“页面文件太小,无法完成操作”的错误。这通常是由于Windows内存分配不足导致的。解决方法包括清理C盘空间和调整虚拟内存大小。具体步骤为:1) 清理桌面、系统文件夹、回收站及浏览器缓存;2) 调整虚拟内存设置。操作后重启电脑即可解决问题。
99 0
|
7月前
|
存储 文件存储
<文件操作> 文件的打开与关闭,顺序读写,随机读写,二进制文件,读取结束的判定,文件缓冲区
<文件操作> 文件的打开与关闭,顺序读写,随机读写,二进制文件,读取结束的判定,文件缓冲区
47 1
|
SQL 关系型数据库 数据库
记一次程序 Bug 导致数据删除的恢复过程
使用RDS、DMS进行数据恢复实践
1005 0
重复文件清除工具,硬盘内存拯救者。。。
重复文件清除工具,硬盘内存拯救者。。。
|
消息中间件 关系型数据库 Shell
记录贴:sentry磁盘占用过大如何清理?
记录贴:sentry磁盘占用过大如何清理?
1240 0
|
安全 关系型数据库 MySQL
为什么延迟复制适用于备库数据的紧急恢复?底层原理是什么?
为什么延迟复制适用于备库数据的紧急恢复?底层原理是什么?
124 0
|
关系型数据库 MySQL
MySQL数据表不能修改、删除等操作,卡死、锁死情况的处理办法。
MySQL数据表不能修改、删除等操作,卡死、锁死情况的处理办法。
1792 0
|
SQL 数据库
数据库页已标记为 RestorePending,可能表明磁盘已损坏。要从此状态恢复,请执行还原操作。
错误提示: 消息 829,级别 21,状态 1,第 1 行 数据库 ID 15,页 (1:21826) 已标记为 RestorePending,可能表明磁盘已损坏。要从此状态恢复,请执行还原操作。 引起原因: RestorePending一般是在进行页恢复的过程中出现的,就是在进行了restore操作之后但还没有进行recovery操作之前页的状态。
2525 0
|
缓存
缓存键重复、冲突带来的数据读取错误
    第二次了,栽在这个问题上, 依然是出自缓存。     需要注意两个问题:     1.根据分类读的数据列表,缓存键需要带上分类ID/分类名称。     2.由于子模块比较多,缓存键命名的时候,整体搜一下是否已存在当前缓存键,否则容易出现多个模块公用一个缓存的现象,导致必有一处数据不对。
950 0
|
SQL
[20180626]延迟块清除与只读表.txt
[20180626]延迟块清除与只读表.txt --//以前测试过延迟块清除与只读表空间的情况.今天测试只读表的情况. --//链接:[20150409]只读表空间与延迟块清除.
1272 0