【C++】C++ 基础进阶【二】开发技巧

简介: C++基础进阶,关于开发环境开发工具的一些便捷使用方式,提高生产力

概述

文章目的: 分享高效快捷的开发技巧,提高开发效率,提升开发过程中的舒适感。

I - 集成开发环境

1.1 - IDE 组成

本章节主要分享一些便捷的功能使用

首先

什么是IDE,它包含哪些功能 ?

集成开发环境,Integrated Development Environment ,简称 IDE。

主要有以下功能:

  • 提高开发效率
  • 工程管理
  • 代码跳转
  • 自动生成 makefile 等

makefile 主要用于建立文件之间工程之间的依赖和连接... 主要体现在编译过程...

一般包含三个部分?

  1. 文本编辑器 (text editor),提供自动补全,语法错误回显,语法/关键字高亮...
  2. 编译器 (compiler) ,例如 MSVC, gcc/g++, MinGW...
    MinGW = Minimalist GNU for Windows,很多库默认不对此编译器做支持,如 QWebEngine,Windows 上一般开发尽量使用 MSVC。

  3. 调试器 (debugger)

1.2 - 便捷方法

1.2.1 - 块选/块编辑

用途:

平时代码选中为行选,有些情况下我们不需要整行的内容,只需要其中一部分内容。

使用方法:

Visual Studio 及 Qt 中,按下键盘 Alt 键,使用鼠标左键选中。

Visual Studio Code 中,则只需按下鼠标中键拖动选中。

块编辑,意思是多行复写,多行写同样的内容,支持复制粘贴,例如下图

blockedit.png

右侧我们可以多行复写多个变量名称 tima,对于定义的结构体,我们可以选中所有的成员变量,并跳过类型,直接粘贴在右侧。省去了一个一个敲或者粘贴的时间。

1.2.2 - 分页

需要多个文件/单个文件不同处编辑或对照代码时,分页可以便捷查看。

功能 \ IDE Qt Visual Studio Code
垂直分页 Ctrl + E, 3 Ctrl + \
水平分页 Ctrl + E, 2 Ctrl + K, Ctrl + \
关闭所有分页 Ctrl + E, 1 Ctrl + Alt + 左方向键

Visual Studio 中

  • 创建选项卡, "窗口 (Window)" → "新建水平选项卡组 (New Horizontal Tab Group)" / "新建垂直选项卡组 (New Vertical Tab Group)"

  • 单文件上下拆分,"窗口 (Window)" → "拆分 (Split)"

两种方式都没有默认快捷键,但可自定义。

"工具 (Tools)" → "选项 (Options)" → "环境 (Enivronment)" → "键盘 (Keyboard)" → 输入快捷键 → 检查无冲突后 → "分配 (Assign)"

1.2.3 - 书签,浏览

用途

多处代码需要查看,添加标签,便于快速切换浏览

使用方法

Visual Studio ,需要在鼠标标记处创建书签,显示书签窗口,双击用于切换至书签位置

功能 快捷键
添加书签 Ctrl + K, Ctrl + K
查看书签 Ctrl + K, Ctrl + W

其他位置快速切换

功能 快捷键
切换至文件头 Ctrl + Home
切换至文件尾部 Ctrl + End

1.2.4 - 代码生成

用途

快速生成函数实现,一个函数包含的必要代码 (类名,函数签名,两个大括号,默认返回值)

使用方法

在函数声明处按下 Alt + 回车,出现菜单后再次回车,默认选项为在对应的源文件中生成函数实现的必要代码。

功能 快捷键
快速添加函数实现 Alt + Enter, Enter

alt+enter.png

左图为 Qt,右图为 Visual Studio

1.2.5 - 注释生成

用途

用于生成注释模板,有些 IDE 如 Qt 内置支持 doxygen 格式的注释

使用方法

Qt 默认的使用方法为在函数前一行,敲 /**/// 后回车,会生成两种不同风格的注释,见下图

cmt.png

Visual Studio 和 Visual Studio Code 默认不支持,但是可以通过安装插件或扩展来实现

  • DoxygenComments (for Visual Studio)
  • cschlosser.doxdocgen-1.2.0.visx (for Visual Studio Code)

扩展不唯一,下载位置:

https://marketplace.visualstudio.com/vscode

1.2.5.1 - Doxygen

首先,Doxygen 是什么?
简而言之,开发文档生成工具,和一套注释规范。

开发文档

开发文档 - developer guide,比如第三方库或开源库的使用说明,github库中的 readme,工程的简介概述,如何在操作系统中部署,以及在代码中如何使用 (初始化,设置...) 等。

工作原理

使用按照规范编写的注释,则可被 doxygen 软件识别,转换成说明文档,并通过代码分析,提取代码结构继承关系等,生成一个有各种开发人员需知内容的参考手册。

可识别的注释三种:

  • JavaDoc
    /**
    * ...批注...
    * /
    
  • Qt
    /*!
    * ...批注...
    * /
    
  • 单行式批注

    /// ...批注...
    
    //! ...批注...
    

另有一些特定标签用于结构化数据
使用 @\ 打头紧跟标签名称示例

/// @param
/// \param
标签 含义
file 文件名
author 作者名
date 日期
version 版本号
brief 简述
details 详情
param 参数
return 返回值

一些注意事项:

  • // 的注释 doxygen 无法识别
  • 不要在头文件和源文件中重复书写同样的文件头内容,会被识别两次,在手册中产生重复冗余的内容,文件头注释只需写在头文件中即可
  • 需要使用 正确的 doxygen 的内置标签 ,自定义标签无法识别,拼写错误的标签一样无法识别,如 detail 无法识别。需要写成 details 多一个 s
    1.2.5.2 - 扩展使用

DoxygenComments 的安装配置方法

  • 1 关闭 Visual Studio,双击进行安装
  • 2 安装完成后,打开 Visual Studio 进入此插件的设置 "工具 (Tools) " → "选项 (Options) " → "Doxygen "
  • 3 Default 子选项内容清空,防止引起冲突
  • 4 Function 子选项用于设置函数注释模板,清空并替换为以下内容

      /// \brief  $END
      /// \param $PARAM
      /// \return $return
    
  • 5 Header 子选项用于设置头文件注释模板,清空并替换为以下内容

      //---------------------------------------------------------
      /// \file    $FILENAME
      /// \brief     $BRIEF $END
      /// \version
      /// \author
      /// \data    $YEAR/$MONTH/$DAY_OF_MONTH
      //---------------------------------------------------------
    

使用时,在头文件第一行输入 //- 即可触发头文件注释模板
在函数声明前一行输入 /// 后回车即可生成函数注释模板

cschlosser.doxdocgen Visual Studio Code 扩展使用

安装完成后,进入此扩展的设置。

  • Doxdocgen > C:Comment Prefix 设置为 /// 三斜杠后写一个空格
  • Doxdocgen > C: First Line & Last Line 清空
  • Doxdocgen > Generic Param Template 设置为 \param {param}
  • Doxdocgen > Order > Edit in settings.json
{
   
    "doxdocgen.generic.order" : [ "brief", "param", "return" ],
}
1.2.5.3 - 颜色设置

有一些 doxygen 注释的默认显示颜色比较暗有点伤视力,可以通过以下方法设置为一些明亮的颜色。

Visual Studio

" 工具 (Tools)" → " 选项 (Options) " → "环境 (Environment) " → "字体和颜色 (Fonts and Colors) " → "显示项 (Display items)" 中找到 "XML 文档注释 (XML Doc Document) "

设置 " 项前景 (Item foreground) " 的 " 自定义 (Custom...) " 选择一个比较明亮的颜色。

Qt

工具选项文本编辑器 → 修改 "Doxgen 注释" 和 "Doxgen 标签" 的 "前景颜色"

qt.png

(需要先复制颜色主题才可以修改)

Visual Studio Code

"设置" → "文本编辑器" → "Font Ligatures" → "在 settings.json 中编辑"

输入以下内容

vscode.png

关于 scope 如何确定 scope 的名称,ctrl + shift + p
Developer: Inspect Editor Tokens and Scope
vscode2.png

1.2.5.4 - Doxygen 其他工具

Graphviz:

绘图工具,生成类之间文件之间关系图,函数调用等,比 doxygen 自身的绘图要详细很多。下载位置:

https://www.graphviz.org/download

HTML Helper Workshop:

压缩 html 文件,生成 .chm 格式手册,下载位置:

https://www.helpandmanual.com/downloads_mscomp.html

关于如何使用 doxygen 见链接:

知乎 doxygen 使用指南

https://zhuanlan.zhihu.com/p/404148142

doxygen 官网

https://www.doxygen.nl/index.html

1.2.6 - 其他快捷键

以下使用的快捷键为 Visual Studio 2019 ,其他版本的 Visual Studio 或有不同。

功能 快捷键
折叠所有方法 Ctrl + M, Ctrl + O
展开所有方法 Ctrl + M, Ctrl + P
展开选中区域 Ctrl + M, Ctrl + E
文字自动换行 Ctrl + E, Ctrl + W
跳转到指定行 Ctrl + G
格式化代码 Ctrl + K, Ctrl + F
注释 Ctrl + K, Ctrl + C
反注释 Ctrl + K, Ctrl + U

折叠所有方法,不仅折叠函数方法,还会折叠宏定义、很适合多重宏隔离的代码开发。

Qt

功能 快捷键
快速注释 Ctrl + \/
格式化代码 Ctrl + I
目录
相关文章
|
3月前
|
机器学习/深度学习 算法 算法框架/工具
为什么使用C++进行机器学习开发
C++作为一种高性能语言,在某些性能要求极高或资源受限的场景下也具有非常重要的地位。C++的高效性和对底层硬件的控制能力,使其在大规模机器学习系统中发挥重要作用,尤其是当需要处理大数据或实时响应的系统时。
57 3
WK
|
1月前
|
机器学习/深度学习 人工智能 算法
那C++适合开发哪些项目
C++ 是一种功能强大、应用广泛的编程语言,适合开发多种类型的项目。它在游戏开发、操作系统、嵌入式系统、科学计算、金融、图形图像处理、数据库管理、网络通信、人工智能、虚拟现实、航空航天等领域都有广泛应用。C++ 以其高性能、内存管理和跨平台兼容性等优势,成为众多开发者的选择。
WK
73 1
|
2月前
|
Rust 资源调度 安全
为什么使用 Rust over C++ 进行 IoT 解决方案开发
为什么使用 Rust over C++ 进行 IoT 解决方案开发
88 7
WK
|
1月前
|
开发框架 移动开发 Java
C++和Java哪个更适合开发移动应用
本文对比了C++和Java在移动应用开发中的优劣,从市场需求、学习难度、开发效率、跨平台性和应用领域等方面进行了详细分析。Java在Android开发中占据优势,而C++则适合对性能要求较高的场景。选择应根据具体需求和个人偏好综合考虑。
WK
54 0
WK
|
1月前
|
安全 Java 编译器
C++和Java哪个更适合开发web网站
在Web开发领域,C++和Java各具优势。C++以其高性能、低级控制和跨平台性著称,适用于需要高吞吐量和低延迟的场景,如实时交易系统和在线游戏服务器。Java则凭借其跨平台性、丰富的生态系统和强大的安全性,广泛应用于企业级Web开发,如企业管理系统和电子商务平台。选择时需根据项目需求和技术储备综合考虑。
WK
83 0
|
2月前
|
NoSQL API Redis
如何使用 C++ 开发 Redis 模块
如何使用 C++ 开发 Redis 模块
|
3月前
|
物联网 C# C语言
物联网开发中C、C++和C#哪个更好用
在物联网(IoT)开发中,C、C++和C#各有优缺点,适用场景不同。C语言性能高、资源占用低,适合内存和计算能力有限的嵌入式系统,但开发复杂度高,易出错。C++支持面向对象编程,性能优秀,适用于复杂应用,但学习曲线陡峭,编译时间长。C#易于学习,与.NET框架结合紧密,适合快速开发Windows应用,但性能略低,平台支持有限。选择语言需根据具体项目需求、复杂性和团队技术栈综合考虑。
|
3月前
|
Java Android开发 C++
🚀Android NDK开发实战!Java与C++混合编程,打造极致性能体验!📊
在Android应用开发中,追求卓越性能是不变的主题。本文介绍如何利用Android NDK(Native Development Kit)结合Java与C++进行混合编程,提升应用性能。从环境搭建到JNI接口设计,再到实战示例,全面展示NDK的优势与应用技巧,助你打造高性能应用。通过具体案例,如计算斐波那契数列,详细讲解Java与C++的协作流程,帮助开发者掌握NDK开发精髓,实现高效计算与硬件交互。
164 1
|
4月前
|
C++
C++ Qt开发:QUdpSocket网络通信组件
QUdpSocket是Qt网络编程中一个非常有用的组件,它提供了在UDP协议下进行数据发送和接收的能力。通过简单的方法和信号,可以轻松实现基于UDP的网络通信。不过,需要注意的是,UDP协议本身不保证数据的可靠传输,因此在使用QUdpSocket时,可能需要在应用层实现一些机制来保证数据的完整性和顺序,或者选择在适用的场景下使用UDP协议。
197 2
|
5月前
|
NoSQL API Redis
c++开发redis module问题之为什么在使用RedisModule_GetApi之前要通过((void**)ctx)[0]这种方式获取其地址
c++开发redis module问题之为什么在使用RedisModule_GetApi之前要通过((void**)ctx)[0]这种方式获取其地址