深入理解QTimer::singleShot的参数,及使用时需要注意的点

本文深入探讨了Qt库中QTimer的singleShot函数,强调了其时间精度选择、lambda表达式使用注意事项以及多线程环境下的槽函数执行线程。在不传递Qt::TimerType时,超时时间小于等于2000ms会使用高精度计时器。错误地使用lambda可能导致对象销毁后的意外调用,正确做法是传入this指针以避免这种情况。此外,接收对象参数决定了槽函数的执行线程,无参数则在调用线程执行,有参数则在接收对象所在线程执行。了解这些细节对于避免程序崩溃和实现预期功能至关重要。

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

singleShot有很多重载函数,各有自己的使用场景,使用不当,容易导致奔溃或者达不到预期。


1、时间精度:

查看源码可知,调用的时候若没有传入Qt::TimerType参数,传入的超时时间小于等于2000ms时,QT自动选择使用精度更高的时钟类型:Qt::PreciseTimer,否则使用精度次高的Qt::CoarseTimer。

2、不恰当使用lambda表达式导致奔溃

如下为singleShot使用lambda的两种常用方式,区别在于第二个参数,为了访问类成员,lambda都捕获this指针。

方式1:若对话框对象在超时前已经销毁,则超时时会调用lambda,而lambda捕获了this指针,这时导致奔溃。

方式2:第二个参数传入this指针,若对话框对象在超时前销毁,超时时间到了也不会调用lambda,所以不会奔溃。

void TestDlg::on_pushButton_clicked()
{    
    //方式1
    QTimer::singleShot(2000, [this]()
    {
        //访问类成员
    });
    
    //方式2
    QTimer::singleShot(2000, this, [this]()
    {
        //访问类成员
    });
}

见QT助手说明: 

 3、多线程环境下,接收对象参数(receiver、context)决定槽函数在哪个线程中执行

1)若传入接收对象参数,槽函数在接收对象所在的线程中执行;

2)若不传入接收对象参数,槽函数在调用线程中执行。

基于上述两点,在项目中需要根据具体情况传入singleShot的参数

### 部署 Stable Diffusion 的准备工作 为了成功部署 Stable Diffusion,在本地环境中需完成几个关键准备事项。确保安装了 Python 和 Git 工具,因为这些对于获取源码和管理依赖项至关重要。 #### 安装必要的软件包和支持库 建议创建一个新的虚拟环境来隔离项目的依赖关系。这可以通过 Anaconda 或者 venv 实现: ```bash conda create -n sd python=3.9 conda activate sd ``` 或者使用 `venv`: ```bash python -m venv sd-env source sd-env/bin/activate # Unix or macOS sd-env\Scripts\activate # Windows ``` ### 下载预训练模型 Stable Diffusion 要求有预先训练好的模型权重文件以便能够正常工作。可以从官方资源或者其他可信赖的地方获得这些权重文件[^2]。 ### 获取并配置项目代码 接着要做的就是把最新的 Stable Diffusion WebUI 版本拉取下来。在命令行工具里执行如下指令可以实现这一;这里假设目标路径为桌面下的特定位置[^3]: ```bash git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git ~/Desktop/stable-diffusion-webui cd ~/Desktop/stable-diffusion-webui ``` ### 设置 GPU 支持 (如果适用) 当打算利用 NVIDIA 显卡加速推理速度,则需要确认 PyTorch 及 CUDA 是否已经正确设置好。下面这段简单的测试脚本可以帮助验证这一情况[^4]: ```python import torch print(f"Torch version: {torch.__version__}") if torch.cuda.is_available(): print("CUDA is available!") else: print("No CUDA detected.") ``` 一旦上述步骤都顺利完成之后,就可以按照具体文档中的指导进一步操作,比如调整参数、启动服务端口等等。整个过程中遇到任何疑问都可以查阅相关资料或社区支持寻求帮助。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值