VsCode 格式化代码风格

本文讲述了作者在升级VSCode到1.85版本后,远程SSH到Linux虚拟机上遇到代码格式化失效的问题,通过安装C/C++插件、删除旧设置、配置VSCode使用clang-format并设置保存自动格式化解决了该问题。
摘要由CSDN通过智能技术生成

背景

       最近在用vscode写代码,由于代码在服务器上,所以我是通过remote-ssh插件远程到linux的虚拟机上。之前用的是vscode 1.67的版本,后面升级到了vscode最新的 1.85版本,发现格式化代码不起作用了。后来研究了一下。

安装 c/c++ 插件

       首先格式化代码是通过 clang-format这个工具进行格式化的,这个工具的获取有两种方式,一种是直接安装clang-format插件,第二种是安装c/c++插件,c/c++插件中会自带这个clang-format,由于我之前安装了 c++插件,所以我采用了第二种方式。

注意点        

1.  这里我建议如果之前有远程过虚拟机,但是升级版本后出问题的,先把虚拟机上的  .vscode-server目录删掉,保证环境单一。

2.  如果有直接在虚拟机上装过  clang-format的也卸载掉。sudo apt remove clang-format  然后在终端执行下 clang-format 如果提示未找到命令说明卸载干净了。

配置VsCode

1. 点vscode左下角的设置图标,选择设置

   

2. 选择扩展->C/C++/格式设置(要是你是英文界面先去把vscode语言设置成中文,自行百度)

注意图片第4步路径的选择,在虚拟机上执行 sudo find / -name clang-format命令,一般.vscode-server/extensions/ms-vscode.cpptools-1.18.5-linux-x64/LLVM/bin 在这个目录下,我那个黄颜色的路径,你要根据自己的插件版本来看,我这里安装的是c/c++ 18.5版本的插件。

然后在第4步这里 填入 xxxxx/clang-format,xxxxx是你自己的路径,最后要把clang-format加上去

3. 把 .clang-format文件放到你的工程根目录下

.clang-format文件如下:(自己建一个.clang-format文件,把下面的拷贝进去)

Language:        Cpp
#BasedOnStyle:    LLVM
AccessModifierOffset: -2
AlignAfterOpenBracket: Align
AlignConsecutiveMacros: false
AlignConsecutiveAssignments: false
AlignConsecutiveDeclarations: false
AlignEscapedNewlines: Left
AlignOperands: true
AlignTrailingComments: true
AllowAllArgumentsOnNextLine: true
AllowAllConstructorInitializersOnNextLine: true
AllowAllParametersOfDeclarationOnNextLine: true
AllowShortBlocksOnASingleLine: false
AllowShortCaseLabelsOnASingleLine: false
AllowShortFunctionsOnASingleLine: None
AllowShortLambdasOnASingleLine: All
AllowShortIfStatementsOnASingleLine: Never
AllowShortLoopsOnASingleLine: false
AlwaysBreakAfterDefinitionReturnType: None
AlwaysBreakAfterReturnType: None
AlwaysBreakBeforeMultilineStrings: false
AlwaysBreakTemplateDeclarations: MultiLine
BinPackArguments: true
BinPackParameters: true
BraceWrapping:
  AfterCaseLabel:  false
  AfterClass:      true
  AfterControlStatement: false
  AfterEnum:       false
  AfterFunction:   true
  AfterNamespace:  false
  AfterObjCDeclaration: false
  AfterStruct:     false
  AfterUnion:      false
  AfterExternBlock: false
  BeforeCatch:     false
  BeforeElse:      false
  IndentBraces:    false
  SplitEmptyFunction: true
  SplitEmptyRecord: true
  SplitEmptyNamespace: true
BreakBeforeBinaryOperators: None
BreakBeforeBraces: Custom
BreakBeforeInheritanceComma: true
BreakInheritanceList: BeforeColon
BreakBeforeTernaryOperators: true
BreakConstructorInitializersBeforeComma: false
BreakConstructorInitializers: BeforeColon
BreakAfterJavaFieldAnnotations: false
BreakStringLiterals: false
ColumnLimit:     120
CommentPragmas:  '^ IWYU pragma:'
CompactNamespaces: false
ConstructorInitializerAllOnOneLineOrOnePerLine: false
ConstructorInitializerIndentWidth: 4
ContinuationIndentWidth: 4
Cpp11BracedListStyle: true
DerivePointerAlignment: false
DisableFormat:   false
ExperimentalAutoDetectBinPacking: false
FixNamespaceComments: true
ForEachMacros:
  - foreach
  - Q_FOREACH
  - BOOST_FOREACH
IncludeBlocks:   Preserve
IncludeCategories:
  - Regex:           '^"(llvm|llvm-c|clang|clang-c)/'
    Priority:        2
  - Regex:           '^(<|"(gtest|gmock|isl|json)/)'
    Priority:        3
  - Regex:           '.*'
    Priority:        1
IncludeIsMainRegex: '(Test)?$'
IndentCaseLabels: true
IndentPPDirectives: AfterHash
IndentWidth:     4
IndentWrappedFunctionNames: false
JavaScriptQuotes: Leave
JavaScriptWrapImports: true
KeepEmptyLinesAtTheStartOfBlocks: false
MacroBlockBegin: ''
MacroBlockEnd:   ''
MaxEmptyLinesToKeep: 1
NamespaceIndentation: All
ObjCBinPackProtocolList: Auto
ObjCBlockIndentWidth: 4
ObjCSpaceAfterProperty: false
ObjCSpaceBeforeProtocolList: true
PenaltyBreakAssignment: 2
PenaltyBreakBeforeFirstCallParameter: 19
PenaltyBreakComment: 300
PenaltyBreakFirstLessLess: 120
PenaltyBreakString: 1000
PenaltyBreakTemplateDeclaration: 10
PenaltyExcessCharacter: 1000000
PenaltyReturnTypeOnItsOwnLine: 60
PointerAlignment: Right
ReflowComments:  true
SortIncludes:    false
SortUsingDeclarations: true
SpaceAfterCStyleCast: false
SpaceAfterLogicalNot: false
SpaceAfterTemplateKeyword: true
SpaceBeforeAssignmentOperators: true
SpaceBeforeCpp11BracedList: false
SpaceBeforeCtorInitializerColon: true
SpaceBeforeInheritanceColon: true
SpaceBeforeParens: ControlStatements
SpaceBeforeRangeBasedForLoopColon: true
SpaceInEmptyParentheses: false
SpacesBeforeTrailingComments: 2
SpacesInAngles:  false
SpacesInContainerLiterals: true
SpacesInCStyleCastParentheses: false
SpacesInParentheses: false
SpacesInSquareBrackets: false
Standard:        Cpp11
StatementMacros:
  - Q_UNUSED
  - QT_REQUIRE_VERSION
TabWidth:        4

 4. 设置保存自动格式化

点击vscode左下角的设置图标,选择设置,在搜索框中搜索格式化。

当然也可以不用设置保存自动格式化,那就需要自己右键对应的文件,然后选择格式化此文档。

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: VSCode中有很多格式化代码的插件,其中比较常用的有以下几种: 1. Prettier:一个流行的代码格式化工具,支持多种语言,可以通过配置文件进行自定义格式化规则。 2. Beautify:支持多种语言的代码格式化插件,可以通过配置文件进行自定义格式化规则。 3. ESLint:一个JavaScript代码检查工具,也可以用于格式化代码。 4. TSLint:一个TypeScript代码检查工具,也可以用于格式化代码。 5. HTMLHint:一个HTML代码检查工具,也可以用于格式化代码。 这些插件都可以通过VSCode插件市场进行下载安装。 ### 回答2: VSCode(Visual Studio Code)是目前非常受欢迎的开源文本编辑器,它提供了丰富的功能和插件来满足开发者的需求。其中,格式化代码插件是VSCode中非常重要的插件之一。 VSCode格式化代码插件可以帮助开发者自动调整代码的格式,使得代码更加可读、整洁。这个插件可以根据代码的语法规范,自动调整代码的缩进、换行、空格等细节,使代码的结构更加清晰、易于阅读,提高代码的可维护性。 使用VSCode格式化代码插件具有以下优势: 1. 提高开发效率:格式化代码插件可以节省开发者手动调整代码格式的时间,尤其是当项目中有多个人共同开发时,保持统一的代码风格非常重要。 2. 保证代码品质:格式化代码插件可以遵循团队约定的代码编写规范,消除不一致的代码格式,确保代码的一致性和可读性,减少出错的机会。 3. 适应多种语言:VSCode格式化插件可以适应各种编程语言,如JavaScript、Python、Java等,使得开发者可以在不同的项目中使用相同的编辑器和插件。 4. 可定制性强:VSCode格式化代码插件通常都支持自定义配置,开发者可以根据自己团队的代码规范进行调整。例如,可以设置缩进为Tab还是空格、缩进的数量、换行的风格等。 总结来说,VSCode格式化代码插件可以帮助开发者提高代码的可读性、减少错误发生的机会,提高团队协作效率。通过自动化调整代码格式,开发者可以更专注于业务逻辑的实现,提高开发效率和代码品质。 ### 回答3: VSCode是一个功能强大的代码编辑器,拥有丰富的插件生态系统。其中,格式化代码插件是开发者常用的插件之一。 VSCode提供了多种格式化代码的插件选择,如Prettier、Beautify等。这些插件可以根据开发者的配置,将代码自动格式化为统一的风格,大大提高了代码的可读性和维护性。 使用格式化代码插件,开发者可以快速美化代码,避免手动调整代码缩进、换行等繁琐的工作。使用插件进行代码格式化可以减少开发者的工作量,节省开发时间。 常见的代码格式化规范包括缩进、对齐、换行等。开发者可以根据自己的喜好和项目要求进行个性化的配置,使代码风格一致而且易于阅读。 除了自动格式化VSCode格式化代码插件还提供了代码审查和错误检测的功能。插件可以帮助开发者找出代码中的潜在问题,并提供修复建议。这大大提高了代码的质量和可靠性。 总之,VSCode格式化代码插件是一款方便实用的工具,能够快速美化代码、提高代码的可读性和维护性、提供代码审查和错误检测等功能。开发者可以根据个人喜好和项目要求进行配置,从而更高效地进行代码开发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值