优化RealTimeImage属性的线程安全性:1. 为get访问器添加线程安全检查 2. 提取SetRealTimeImageInternal内部方法处理实际设置逻辑 3. 改进异常处理和资源管理

This commit is contained in:
zqm
2025-11-06 11:03:30 +08:00
parent 05bd08647c
commit 8917403659

View File

@@ -107,6 +107,11 @@ namespace JoyD.Windows.CS
{
get
{
// 读取操作也需要线程安全检查
if (this.InvokeRequired)
{
return (Image)this.Invoke(new Func<Image>(() => mRealTimeImage));
}
return mRealTimeImage;
}
set
@@ -116,38 +121,57 @@ namespace JoyD.Windows.CS
{
try
{
this.BeginInvoke(new Action<Image>((img) => RealTimeImage = img), value);
// 使用Action委托设置值避免闭包问题
this.BeginInvoke(new Action<Image>(SetRealTimeImageInternal), value);
}
catch (ObjectDisposedException)
{
// 控件已释放,释放传入的图像
// 控件已释放,释放传入的图像资源
value?.Dispose();
}
return;
}
// 防止重复设置相同的图像
if (mRealTimeImage == value)
return;
// 检查是否在有效状态下操作
if (this.IsDisposed || this.Disposing)
{
// 如果窗口已关闭或正在关闭,释放传入的图像
value?.Dispose();
return;
}
// 释放旧图像
if (mRealTimeImage != null && mRealTimeImage != value)
{
try { mRealTimeImage.Dispose(); } catch { }
}
// 只设置mRealTimeImage不直接更新UI
// UI更新将由定时器的Timer_Tick事件处理
mRealTimeImage = value;
// 在UI线程上直接调用内部方法
SetRealTimeImageInternal(value);
}
}
/// <summary>
/// 内部方法在UI线程上安全地设置实时图像
/// </summary>
/// <param name="value">要设置的新图像</param>
private void SetRealTimeImageInternal(Image value)
{
// 防止重复设置相同的图像
if (mRealTimeImage == value)
return;
// 检查是否在有效状态下操作
if (this.IsDisposed || this.Disposing)
{
// 如果窗口已关闭或正在关闭,释放传入的图像
value?.Dispose();
return;
}
// 释放旧图像资源
if (mRealTimeImage != null && mRealTimeImage != value)
{
try
{
mRealTimeImage.Dispose();
}
catch (Exception ex)
{
// 记录异常但不中断流程
System.Diagnostics.Debug.WriteLine($"释放旧图像资源失败: {ex.Message}");
}
}
// 只设置mRealTimeImage不直接更新UI
// UI更新将由定时器的Timer_Tick事件处理
mRealTimeImage = value;
}
}
}