【Qt/C++】深入理解 Lambda 表達式與 `mutable` 關鍵字的使用

【Qt/C++】深入理解 Lambda 表達式與 mutable 關鍵字的使用

在 Qt 開發中,我們常常會用到 lambda 表達式來編寫簡潔的槽函數。今天通過一個實際代碼示例,詳細講解 lambda 的語法、變量捕獲方式,特別是 mutable 的作用。

示例代碼

QPushButton * myBtn = new QPushButton(this);
QPushButton * myBtn2 = new QPushButton(this);
myBtn2->move(100, 100);
int m = 10;connect(myBtn, &QPushButton::clicked, this, [m]() mutable {m = 100 + 10;qDebug() << m;
});connect(myBtn2, &QPushButton::clicked, this, [=]() {qDebug() << m;
});qDebug() << m;

一、Lambda 表達式基本結構

Lambda 表達式的完整語法如下:

[capture](parameter_list) mutable -> return_type {// function body
};

每個部分含義如下:

  • [capture]:捕獲列表,決定 lambda 能訪問哪些外部變量以及如何訪問;
  • (parameter_list):傳入 lambda 的參數;
  • mutable(可選):允許修改捕獲的變量副本;
  • -> return_type(可選):指定返回類型;
  • { ... }:函數體。

二、示例中的捕獲方式說明

connect(myBtn, ..., [m]() mutable {...})

  • [m] 表示 按值捕獲 變量 m。lambda 拿到的是 m 的拷貝;
  • mutable 關鍵字允許修改這個拷貝,否則按值捕獲的變量在 lambda 中默認是 const 的;
  • 這段代碼中,m = 100 + 10; 是合法的,因為 mutable 去除了 m 的只讀限制;
  • 需要注意,這種修改只作用在拷貝上,不影響外部的 m

connect(myBtn2, ..., [=]() {...})

  • [=] 表示 按值捕獲所有外部變量
  • 沒有加 mutable,所以 lambda 內部對 m 是只讀的;
  • qDebug() << m; 打印的是外部 m 的原始值,即 10

三、mutable 的關鍵作用

默認情況下,按值捕獲的變量在 lambda 中是 const 的:

int x = 5;
auto func = [x]() {x = 10; // 編譯錯誤!x 是 const
};

加上 mutable 后就允許修改:

int x = 5;
auto func = [x]() mutable {x = 10; // 合法,修改的是 x 的副本
};

這在一些涉及臨時變量處理的場景中非常有用,尤其是在 Qt 信號槽連接中修改狀態時。

四、輸出結果分析

假設用戶點擊了 myBtnmyBtn2

  1. qDebug() << m; 最初輸出 10

  2. 點擊 myBtn

    • 輸出 110,是 lambda 拷貝的 m 被修改;
  3. 點擊 myBtn2

    • 輸出 10,lambda 看到的仍是最初的 m 值,因為它是按值捕獲的;
    • 沒有使用 mutable,無法修改。

五、最佳實踐建議

  • 若只需要讀取變量,推薦用 [=] 捕獲;
  • 若要修改變量拷貝,用 [x] mutable
  • 若想修改外部變量本體,使用 引用捕獲 [&x]
  • 警惕 [&] 捕獲所有變量引用,雖然方便但易引發生命周期錯誤。

總結

捕獲方式說明可修改?是否影響外部變量
[m]按值捕獲變量 m? 默認不可以
? 使用 mutable
? 不影響
[=]按值捕獲所有變量??
[&m]引用捕獲變量 m??
[&]引用捕獲所有變量??

通過這個例子,希望你能對 lambda 表達式的使用和 mutable 關鍵字有更深入的理解,特別是在 Qt 的信號槽連接中,lambda 是一種高效優雅的解決方案。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/82544.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/82544.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/82544.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

記錄 ubuntu 安裝中文語言出現 software database is broken

搜索出來的結果是 sudo apt-get install language-pack-zh-han* 然而,無效,最后手動安裝如下 apt install language-pack-zh-hans apt install language-pack-zh-hans-base apt install language-pack-gnome-zh-hans apt install fonts-arphic-uming apt install libreoffic…

[虛幻官方教程學習筆記]深入理解實時渲染(An In-Depth Look at Real-Time Rendering)

原英文教程地址深入理解實時渲染&#xff08;An In-Depth Look at Real-Time Rendering&#xff09; 文章目錄 1.Intro to An In-Depth Look at Real-Time RenderingCPU VS GPUDeferred VS Forward 2. Before Rendering and OcclusionCulling計算的步驟使用console command:fre…

Linux進程間信號

目錄 信號入門 生活角度中的信號 技術應用角度的信號 信號的發送與記錄 信號處理常見方式概述 產生信號 通過終端按鍵產生 通過系統函數向進程發信號 由軟件條件產生信號 由硬件異常產生信號 阻塞信號 信號其他相關常見概念 在內核中的表示 sigset_t 信號集操作…

Git簡介和發展

Git 簡介 Git是一個開源的分布式版本控制系統&#xff0c;跨平臺&#xff0c;支持Windows、Linux、MacOS。主要是用于項目的版本管理&#xff0c;是由林納斯托瓦茲(Linux Torvalds)在2005年為Linux內核開發而創建。 起因 在2002年至2005年間&#xff0c;Linux內核開發團隊使…

Perspective,數據可視化的超級引擎!

Perspective 是一個強大的交互式數據分析和可視化庫&#xff0c;它允許你創建高度可配置的報告、儀表板、筆記本和應用程序。給用戶提供了一個新的視角來看待數據。 Stars 數9125Forks 數1217 主要特點 高效流式查詢引擎&#xff1a;Perspective使用C編寫&#xff0c;并編譯為…

MySQL COUNT(*) 查詢優化詳解!

目錄 前言1. COUNT(*) 為什么慢&#xff1f;—— InnoDB 的“計數煩惱” &#x1f914;2. MySQL 執行 COUNT(*) 的方式 (InnoDB)3. COUNT(*) 優化策略&#xff1a;快&#xff01;準&#xff01;狠&#xff01;策略一&#xff1a;利用索引優化帶 WHERE 子句的 COUNT(*) (最常見且…

如何在postman使用時間戳

1. 使用 Pre-request Script 動態轉換? 在發送請求前&#xff0c;將日期字符串轉為時間戳并存儲為環境變量/全局變量。 ?示例代碼? // 將日期字符串&#xff08;如 "2023-10-01"&#xff09;轉為時間戳&#xff08;毫秒&#xff09; const dateString "2…

嵌入式學習筆記 - 運算放大器的共模抑制比

一 定義 共模抑制比&#xff08;Common Mode Rejection Ratio, ?CMRR?&#xff09;是衡量差分放大器&#xff08;或差分電路&#xff09;抑制共模信號能力的關鍵指標。它在電子工程中尤為重要&#xff0c;特別是在需要處理微弱信號或對抗環境噪聲的場景中。 核心概念 ?共…

成龍電影中的三菱汽車

帕杰羅、 Lancer Evolution、 3000GT Mitsubishi Lancer Evo ll 1995 附錄 Mercedes-Benz 280SL&#xff08;W113&#xff09;&#xff0c;俗稱“Pagoda”&#xff08;帕格達&#xff09;

Spring 項目無法連接 MySQL:Nacos 配置誤區排查與解決

在開發過程中&#xff0c;我們使用 Nacos 來管理 Spring Boot 項目的配置&#xff0c;其中包括數據庫連接配置。然而&#xff0c;在實際操作中&#xff0c;由于一些概念的混淆&#xff0c;我們遇到了一些連接問題。本文將分享我的故障排查過程&#xff0c;幫助大家避免類似的錯…

LabVIEW與 IMAQ Vision 機器視覺應用

在工業生產及諸多領域&#xff0c;精確高效的檢測至關重要。基于 LabVIEW 與 IMAQ Vision 的機器視覺應用&#xff0c;深入剖析其原理、系統構成、軟件設計及優勢&#xff0c;為相關領域工程師提供全面技術參考。 ? 一、技術原理 &#xff08;一&#xff09;機器視覺技術基礎…

【STM32 學習筆記】USART串口

注意&#xff1a;在串口助手的接收模式中有文本模式和HEX模式兩種模式&#xff0c;那么它們有什么區別&#xff1f; ??文本模式和Hex模式是兩種不同的文件編輯或瀏覽模式&#xff0c;不是完全相同的概念。文本模式通常是指以ASCII編碼格式表示文本文件的編輯或瀏覽模式。在文…

【WPS】怎么解決“word的復制表格”粘貼到“excel的單元格”變多行單元格的問題

把 word文檔復制表格到這個excel表格上面的話&#xff0c;會出現由單個單元格變成多行單元格的情況。 現在&#xff0c;就這個問題怎么解決&#xff0c;提出了一個方案&#xff0c;就是先查找是什么導致了這個換行&#xff0c;然后再將換行的這個字符進行一個整體的替換&#x…

嵌入式開發面試題詳解:STM32 與嵌入式開發核心知識全面解析

一、STM32 共有幾種基本時鐘信號&#xff1f; 題目 STM32 共有幾種基本時鐘信號&#xff1f; 解答 STM32 包含 4 種基本時鐘信號&#xff0c;分別為 HSI&#xff08;內部高速時鐘&#xff09;、HSE&#xff08;外部高速時鐘&#xff09;、LSI&#xff08;內部低速時鐘&…

華為策略路由

路由策略&#xff1a;是對路由條目進行控制&#xff0c;通告控制路由條目影響報文的轉發路徑。路由策略為控制平面。 策略路由&#xff1a;是根據報文特征&#xff0c;認為的控制報文從某個即可轉發出去&#xff0c;不修改路由表。即策略路由為在轉發平面。 路由策略 策略路由…

# YOLOv3:深度學習中的目標檢測利器

YOLOv3&#xff1a;深度學習中的目標檢測利器 引言 在計算機視覺領域&#xff0c;目標檢測是一項核心任務&#xff0c;它涉及到識別圖像或視頻中的物體&#xff0c;并確定它們的位置。隨著深度學習技術的快速發展&#xff0c;目標檢測算法也在不斷進步。YOLO&#xff08;You …

紅黑樹刪除的實現與四種情況的證明

&#x1f9ed; 學習重點 刪除節點的三種情況紅黑樹如何恢復性質四種修復情況完整可運行的 C 實現 一、紅黑樹刪除的基礎理解 紅黑樹刪除比插入復雜得多&#xff0c;因為&#xff1a; 刪除的是黑節點可能會破壞“從根到葉子黑節點數相等”的性質。刪除紅節點無需修復&#xf…

vue配置代理解決前端跨域的問題

文章目錄 一、概述二、報錯現象三、通過配置代理來解決修改request.js中的baseURL為/api在vite.config.js中增加代理配置 四、參考資料 一、概述 跨域是指由于瀏覽器的同源策略限制&#xff0c;向不同源(不同協議、不同域名、不同端口)發送ajax請求會失敗 二、報錯現象 三、…

T-SQL在SQL Server中判斷表、字段、索引、視圖、觸發器、Synonym等是否存在

SQL Server創建或者刪除表、字段、索引、視圖、觸發器前判斷是否存在。 目錄 1. SQL Server創建表之前判斷表是否存在 2. SQL Server新增字段之前判斷是否存在 3. SQL Server刪除字段之前判斷是否存在 4. SQL Server新增索引之前判斷是否存在 5. SQL Server判斷視圖是否存…

金融企業如何借力運維監控強化合規性建設?

日前&#xff0c;國家金融監督管理總局網站公布行政處罰信息&#xff0c;認定某銀行存在多項違規并對其進行罰款。其中&#xff0c;國家金融監督管理總局認定該銀行主要違規內容包括&#xff1a; 一、部分重要信息系統識別不全面&#xff0c;災備建設和災難恢復能力不符合監管要…