UE4 4.24.3版本,编辑器Output Log窗口中,右键--Clear Log操作很大概率会导致编辑器奔溃;
解决办法:

相关文件:

Engine\Source\Developer\OutputLog\Private\SOutputLog.cpp

Engine\Source\Developer\OutputLog\Private\SOutputLog.h

SOutputLog.h文件中添加:

bool bNeedClearLog;
void DoClearLog();

SOutputLog.cpp文件修改:

void SOutputLog::Construct( const FArguments& InArgs ){
...
bNeedClearLog = false;
}

void SOutputLog::OnClearLog()
{
bNeedClearLog = true;
} void SOutputLog::DoClearLog() {
if (bNeedClearLog)
{
// Make sure the cursor is back at the start of the log before we clear it
MessagesTextBox->GoTo(FTextLocation(0)); MessagesTextMarshaller->ClearMessages();
MessagesTextBox->Refresh();
bIsUserScrolled = false;
bNeedClearLog = false;
}
} void SOutputLog::Tick(const FGeometry& AllottedGeometry, const double InCurrentTime, const float InDeltaTime)
{
DoClearLog();
...
}

分析:

先前的实际Clear代码是在OnClearLog()函数中调用的,这个函数应该是在鼠标点击事件调用栈中执行的;

将实际Clear代码移动到DoClearLog()函数中,并在Tick()函数中调用,也就是移动到渲染循环中执行;

通过bNeedClearLog标识,Tick中是否需要执行真正的Clear操作;
这些改动,在实际测试中证实能够避免ClearLog操作导致Editor奔溃

猜测原因:
之前会奔溃,猜测是鼠标事件调用和渲染不是在同一个线程中,而Clear操作,实际上在清理Log列表(一个TArray对象),会比较耗时;
另外,在Editor中可以观察到,当ClearLog所在的ContentMenu打开时,Eidtor World是处于暂停状态的,点击ClearLog,ContentMenu立即关闭,Eidtor World恢复运行状态;

这里面不知道有没有调用先后关系的问题,只能等以后对Slate框架源码有更多的认识才能知道;

#2020/9/8更新
今天在UE4 QQ群里面有讨论ClearLog导致Editor崩溃的问题,有人提到,奔溃原因是输入发导致;
目前使用的是Windows10自带的微软拼音输入法,在语言栏的设置中,打开输入设置界面,关闭里面的所有开关后,同样的操作Editor确实不再崩溃了
具体是那个输入法功能导致的Editor奔溃没有一一测试;

因为没有安装其他常用输入法,就没有一一测试了;

有需要的可以尝试关闭一些输入法功能试试看;

#2020/12/17更新

距离上次更新好长一段时间了

期间一直在忍受ClearLog奔溃的问题;9/8号更新的方法:调整输入法设置并不起多大作用,或者根本不起作用吧!这个奔溃问题本来也是有概率出现的bug;

前面的操作思路是把Clear动作跳过鼠标点击回调,延迟到tick中执行;
这几天稍微改动一下,基本思路是往后延迟几帧再执行Clear动作;

添加一个帧计数:

SOutputLog.h头文件中添加:

int frameCount;

SOutputLog.cpp文件修改:

void SOutputLog::OnClearLog()
{
bNeedClearLog = true;
frameCount = 3;
} void SOutputLog::DoClearLog()
{
if (frameCount > 0)
{
frameCount--;
}
else
{
if (bNeedClearLog)
{
// Make sure the cursor is back at the start of the log before we clear it
MessagesTextBox->GoTo(FTextLocation(0)); MessagesTextMarshaller->ClearMessages();
MessagesTextBox->Refresh();
bIsUserScrolled = false;
bNeedClearLog = false;
}
}
}

不同工程尝试过几次,貌似有效;至于是不是没碰到概率事件让时间来验证;

修复UE4编辑器,ClearLog操作导致的崩溃的更多相关文章

  1. 给虚拟机添加新硬盘并分区,fdisk查看分区,分区,重新读取分区表信息partprobe,格式化,挂载,查看分区挂载信息,自动挂载文件/etc/fstab,/etc/fstab文件错误导致重启崩溃后的修复

    1.虚拟机关机断电 2.添加硬盘 2.开机 3.fdisk -l查看刚才新添加的硬盘 [root@localhost ~]# fdisk -l 磁盘 /dev/sda:21.5 GB, 2147483 ...

  2. 安装glibc错误链接导致系统崩溃,u盘启动紧急救援模式下修复系统。

    Sln 命令  创建动态符号链接 用法 sln source  dest 故障案例:一个误操作 导致了一个不小的故障,输入所有命令都无效,直接系统无法启动. 故障描述 sln /usr/lib64/l ...

  3. WPF 线程中异常导致程序崩溃

    一般我们WPF中都加全局捕获,避免出现异常导致崩溃. Application.Current.DispatcherUnhandledException += Current_DispatcherUnh ...

  4. 解决方案-问题001:物理机、虚机等等Linux操作系统/usr/bin目录权限误操作,导致无法切换root

    导语:平常运维人员会误操作一些目录权限,导致一些问题,那么如何恢复呢? 问题:物理机.虚机等等Linux操作系统/usr/bin目录权限误操作,导致无法切换root? 实验环境: ip地址 是否目录正 ...

  5. 如何规避容器内做Java堆dump导致容器崩溃的问题

    写在前边 最近公司生产环境的容器云上出了个性能问题,为了做性能分析,使用 JDK 自带的 jmap 收集堆dump,出现了内存溢出导致了容器崩溃. 本篇文章将带你探究,如何规避容器内做堆 dump 导 ...

  6. 线程崩溃为什么不会导致 JVM 崩溃

    大家好,我是坤哥 网上看到一个很有意思的据说是美团的面试题:为什么线程崩溃崩溃不会导致 JVM 崩溃,这个问题我看了不少回答,但都没答到根本原因,所以决定答一答,相信大家看完肯定会有收获,本文分以下几 ...

  7. WCF:没有终结点在侦听可以接受消息的*这通常是由于不正确的地址或者 SOAP操作导致的。

    没有终结点在侦听可以接受消息的 http://xx.com/WebService.svc. 这通常是由于不正确的地址或者 SOAP 操作导致的.如果存在此情况,请参见 InnerException 以 ...

  8. WCF: 没有终结点在侦听可以接受消息的 这通常是由于不正确的地址或者 SOAP 操作导致的。

    问题:     由于我这里的wcf服务是采用“BasicHttpBinding”的方式,即安全绑定模式,客户端在引用这个服务后所生成的终结点配置(endpoint )就变成了<endpoint ...

  9. 客服端调用自定义宿主的WCF报错"没有终结点在侦听可以接受消息的http://localhost:8085/mex。这通常是由于不正确的地址或者 SOAP 操作导致的错误"的解决方案。

    没有终结点在侦听可以接受消息的http://localhost:8085/mex.这通常是由于不正确的地址或者 SOAP 操作导致的错误. 这个错误是由于没有启动元数据交换终结点(MEX)导致的.在宿 ...

随机推荐

  1. Kubernetes集群环境搭建全过程

    资源准备以及服务器初始化 所有服务器执行一下脚本进行配置信息初始化: #!/bin/bash cd `dirname $0` # 关闭selinux setenforce 0 sed -i '/SEL ...

  2. UVA-1498 Activation

    UVA-1498 DP应该是肯定的,设 f [ i ] [ j ] 表示现在对中共有 i 人,Tomato在第 j 个,出现所求情况的概率,我们可以很(简单的)艰难的列出下列方程: f[i][1] = ...

  3. [经验] 电源抑制比(PSRR)的测量原理及解决方法

    PSRR(Power supply rejection ratio)又称电源抑制比,是衡量电路对于输入电源中纹波抑制大小的重要参数,表示为输出纹波和输入纹波的对数比,单位为分贝(dB)[1],其计算公 ...

  4. Python课程笔记(七)

    今天学习神奇的海龟,非常有意思,还有很多图片想去绘制,分享一个turtle绘图网站: https://www.python123.io/index/turtles/latest , 要是可以分享出源码 ...

  5. 第35篇-方法调用指令之invokespecial与invokestatic

    这一篇将详细介绍invokespecial和invokestatic字节码指令的汇编实现逻辑 1.invokespecial指令 invokespecial指令的模板定义如下: def(Bytecod ...

  6. nginx 支持https访问

    1,先确认nginx安装时已编译http_ssl模块. 就是执行nginx -V命令查看是否存在--with-http_ssl_module.如果没有,则需要重新编译nginx将该模块加入.yum安装 ...

  7. appium环境搭建基于安卓(mac系统)

    1.需要环境 JDK Python Andriod SDK Node.js Appium Appium-Python-Client Appium-doctor 2.安装jdk(我的版本是1.8) 下载 ...

  8. 第12组 Alpha冲刺 (1/6)

    过去两天完成了哪些任务 文字描述 静态页面代码编写以及一些点击事件 展示GitHub当日代码/文档签入记录 接下来的计划 1.继续学习echarts 2.编写所需要的图表代码 还剩下哪些任务 1.图表 ...

  9. 问题 D: 某种序列

    题目描述 数列A满足An = An-1 + An-2 + An-3, n >= 3  编写程序,给定A0, A1 和 A2, 计算A99 输入 输入包含多行数据  每行数据包含3个整数A0, A ...

  10. mysql 数据库中 int(3) 和 int(11) 有区别么???

    今天去面试的时候 面试官问到了这个问题:int(3) 和 int(11) 有什么区别?? 当时一听有点蒙,(不知道为什么蒙,后来回来想想可能是觉得考官怎么会问这么简单的问题呢,所以蒙了),当时我的回答 ...