c++编码风格指南_100%正确编码样式指南

c++编码风格指南

Tabs or spaces? Curly brace on the same line or a new line? 80 character width or 120?

制表符或空格? 在同一行或新行上大括号? 80个字符的宽度还是120个字符?

Coders love to argue about this kind of stuff. The tabs vs. spaces debate even made it into a famous episode of the HBO show Silicon Valley.

编码人员喜欢争论这种事情。 标签与空间的辩论甚至使它成为了HBO节目《 硅谷》中的著名一集 。

Well in this article, I will finally give you the definitive answers you seek.

好吧,在本文中,我将最终为您提供确定的答案。

Early in my career, I engaged in all kinds of holy wars. I would read some article about why a particular convention was correct, while another was totally wrong. I would get right up there on my high and mighty horse and proclaim to anyone who would listen that they were wrong and I was right.

在我职业生涯的早期,我参加了各种圣战。 我会读一些文章,说明为什么某个特定约定正确,而另一个完全错误。 我会骑着高大而有力的马上去,向任何听他们说错了而我是对的人宣告。

It took me years to find the right answers but I’ve finally done it and it turns out the answer is…

我花了多年的时间才找到正确的答案,但我终于做到了,事实证明答案是…

These things don’t matter.

这些都没关系。

Consistency matters. Readability matters. Arguing and stressing about one convention over another matters not.

一致性很重要。 可读性很重要。 争论和强调一个公约而不是另一个公约并不重要。

Over the past 20+ years, I’ve followed every imaginable trend. I’ve followed the different conventions of different languages. None of it has impacted my bug count or made my code any more efficient.

在过去的20多年中,我一直关注着每一个可以想象的趋势。 我遵循了不同语言的不同约定。 这些都不会影响我的错误计数或提高我的代码效率。

Don’t get me wrong, clean-looking, well-formatted code will be easier to change and maintain over time, and that’s a good thing.

别误会,外观简洁,格式正确的代码将随着时间的推移更易于更改和维护,这是一件好事。

There’s also nothing wrong with wanting your code to look beautiful. But too often, this is used to justify what essentially boils down to procrastination.

希望代码看起来很漂亮也没有错。 但是很多时候,这是用来证明本质上归结为拖延的理由。

We procrastinate like this because coding is hard. Things can get complicated in a hurry and we — especially those of us who may be new to this level of complexity — can become intimidated by this complexity and grow insecure about our ability to tame it.

我们这样拖延是因为编码很难。 事情可能会急忙变得复杂,而我们-尤其是对于那些刚刚接触到这种复杂性水平的人-可能会被这种复杂性吓倒,并对我们驯服它的能力变得不安全。

It’s much safer to argue over trivial things. Our perceived incompetence is less likely to be exposed that way.

在琐碎的事情上争论要安全得多。 我们认为自己的无能这样暴露的可能性较小。

The phenomena of debating trivialities to avoid hard problems is so common that there are a number of popular theories that describe it.

为了避免难题而进行琐碎辩论的现象非常普遍,以至于有许多流行的理论对此进行了描述。

One of the most popular is Parkinson’s Law of Triviality which states that members of an organization give disproportionate weight to trivial issues.

最受欢迎的方法之一是帕金森的琐碎法则,其中指出组织成员对琐碎问题的重视程度过高。

In illustrating this law, Parkinson used the fictional example of a committee whose job it was to approve plans for a new nuclear plant, but who spent the majority of their time arguing over what materials to use for the staff bike shed. They neglected the proposed design of the plant itself, which was a far more important but also far more complex issue.

在说明这项法律时,帕金森举了一个虚构的例子来说明这个委员会的工作,该委员会的工作是批准新核电站的计划,但他花了大部分时间在讨论用于员工自行车棚的材料。 他们忽略了工厂本身的拟议设计,这不仅是重要的问题,而且也是更为复杂的问题。

Because of the reference to a bike shed in this canonical example, Danish developer, Poul-Henning Kamp later coined the term “bike shed effect” or simply “bike shedding” to describe it.

由于在此典型示例中提到了自行车棚,丹麦开发商Poul-Henning Kamp后来创造了术语“自行车棚效应”或简称为“自行车脱落”来描述它。

If you work in software development — and especially if you hang out with other coders on social media — you’re likely to come across some form of bike-shedding almost daily.

如果您从事软件开发工作,特别是如果您在社交媒体上与其他编码员一起闲逛,那么您几乎每天都可能会碰到某种形式的骑自行车。

If you find yourself getting into an unusually heated debate with your fellow coders, online or in-person, it’s probably also worth remembering Sayre’s Law

如果您发现自己与在线或面对面的编码员展开了异常激烈的辩论,那么也有必要记住塞勒定律 ……

“In any dispute the intensity of feeling is inversely proportional to the value of the issues at stake.”
“在任何争议中,感觉的强度与所涉问题的价值成反比。”

As a consultant, I bounce from client to client, and each one has their own rules and conventions. I decided long ago that the only way for me to succeed was to let go of the trivialities and focus on the hard problems. When it comes to coding standards, I take what I get and I don’t get upset.

作为顾问,我在客户之间跳来跳去,每个人都有自己的规则和约定。 我很久以前就决定,我要成功的唯一方法就是放下琐碎的事,集中精力解决棘手的问题。 当涉及到编码标准时,我会接受,但不会感到沮丧。

If you happen to find yourself in a position to pick your own style guide, I recommend that you ask yourself these two simple questions:

如果您碰巧发现自己可以选择自己的风格指南,则建议您自问以下两个简单问题:

  1. Is there tooling that will automatically apply the style rules to my code with little to no intervention from me?

    是否有工具可以将样式规则自动应用于我的代码,而几乎不需要我干预?
  2. Are the tools and underlying styles actively maintained and/or used by reputable organizations?

    信誉良好的组织是否积极维护和/或使用了工具和基础样式?

If you can answer “yes” to both of those questions, then you’re good to go. Simple as that.

如果您对这两个问题都回答“是”,那么您就很好了。 就那么简单。

Here are some options that fit the bill for some of today’s more popular web languages:

以下是一些适合当今一些较流行的网络语言的选项:

DotNet Code Formatter

DotNet代码格式化程序

Java: Google-Java-Format

Java:Google Java格式

Javascript Standard Style (N.B. this is a product name, not an actual, official JavaScript standard)

Javascript标准样式 (注意,这是产品名称,而不是实际的官方JavaScript标准)

PHP Coding Standards Fixer

PHP编码标准修复程序

Python: Google’s YAPF

Python:Google的YAPF

Ruby: Rubocop

Ruby:Rubocop

If you enjoyed this article, please smash the clap icon at the bottom of this post repeatedly to help spread the word. And if you want to read more stuff like this, please sign up for my weekly Dev Mastery newsletter below.

如果您喜欢这篇文章,请反复粉碎这篇文章底部的拍手图标,以帮助传播这个词。 如果您想类似的内容,请在下面注册我的每周开发精通通讯。

翻译自: https://www.freecodecamp.org/news/the-100-correct-coding-style-guide-5b594a1655f0/

c++编码风格指南

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/395666.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Netty源码注释翻译-Channel类

定义为一个通往网络socket或者一个由I/O读写能力的组件。 通道提供: 1,通道的当前状态,打开?已连接? 2,跟通道关联的配置信息ChannelConfig,包括buffer大小等。 3,通道支持的I/O操作…

Today is weekend不是应该一定会输出吗

判断语句 If…else块&#xff0c;请看下面这个例子&#xff1a; <%! int day 3; %>                       //声明变量感叹号 <html> <head><title>IF...ELSE Example</title></head> <body> <% if (day …

时间模块和时间工具

一、time模块 三种格式 时间戳时间&#xff1a;浮点数 单位为秒 时间戳起始时间&#xff1a; 1970.1.1 0:0:0 英国伦敦时间 1970.1.1 8:0:0 我国(东8区) 结构化时间&#xff1a;元组(struct_time) 格式化时间&#xff1a;str数据类型的 1、常用方法 import timetime.sleep(secs…

redux扩展工具_用鸭子扩展您的Redux App

redux扩展工具How does your front-end application scale? How do you make sure that the code you’re writing is maintainable 6 months from now?您的前端应用程序如何扩展&#xff1f; 您如何确定您正在编写的代码从现在起6个月内可维护&#xff1f; Redux took the …

mac下源码安装redis

转载&#xff1a;http://www.jianshu.com/p/6b5eca8d908b 下载安装包 redis-3.0.7.tar.gz 官网地址&#xff1a;http://redis.io/download 解压&#xff1a;tar -zvxf redis-3.0.7.tar.gz 将解压后的文件夹放到 /usr/local目录下 编译测试:接下来在终端中切换到/usr/local/red…

代码扫描工具测试覆盖率工具

测试覆盖率工具转载于:https://www.cnblogs.com/vivian-test/p/5398289.html

php splqueue 5.5安装,解析PHP标准库SPL数据结构

SPL提供了双向链表、堆栈、队列、堆、降序堆、升序堆、优先级队列、定长数组、对象容器SplQueue 队列类进出异端&#xff0c;先进先出<?php $obj new SplQueue();//插入一个节点到top位置$obj->enqueue(1);$obj->enqueue(2);$obj->enqueue(3);/**SplQueue Object…

Beta阶段敏捷冲刺总结

设想和目标 1. 我们的软件要解决什么问题&#xff1f;是否定义得很清楚&#xff1f;是否对典型用户和典型场景有清晰的描述&#xff1f; 在最开始的时候我们就是为了解决集美大学计算机工程学院网页没有搜索引擎的问题。因为没有搜索引擎&#xff0c;在搜索内容时需要根据查找信…

c语言 二进制压缩算法_使用C ++解释的二进制搜索算法

c语言 二进制压缩算法by Pablo E. Cortez由Pablo E.Cortez 使用C 解释的二进制搜索算法 (Binary Search Algorithms Explained using C) Binary search is one of those algorithms that you’ll come across on every (good) introductory computer science class. It’s an …

【LATEX】个人版latex论文模板

以下是我的个人论文模板&#xff0c;运行环境为Xelatex(在线ide&#xff1a;Sharelatex.com) 鉴于本人常有插入程序的需求&#xff0c;故引用了lstlisting \RequirePackage{ifxetex} \ifxetex\documentclass[hyperref, UTF8, c5size, no-math, winfonts&#xff0c;a4paper]{ct…

初识virtual memory

一、先谈几个重要的东西 virtual memory是一个抽象概念&#xff0c;书上的原文是"an abstraction of main memory known as virtual memory"&#xff08;参考资料p776&#xff09;。那么什么是抽象概念。下面说说我个人对这个东西的理解。 所谓抽象概念是指抽象出来的…

java创建mysql驱动,JDBC之Java连接mysql实现增删改查

使用软件&#xff1a;mysql、eclipse链接步骤&#xff1a;1.注册驱动2.创建一个连接对象3.写sql语句4.执行sql语句并返回一个结果或者结果集5.关闭链接(一般就是connection、statement、setresult)这三个连接对象&#xff0c;关闭顺序一般是(setresult ---> statement …

算法第五章作业

1.你对回溯算法的理解&#xff08;2分&#xff09; 回溯法&#xff08;探索与回溯法&#xff09;是一种选优搜索法&#xff0c;又称为试探法&#xff0c;按选优条件向前搜索&#xff0c;以达到目标。但当探索到某一步时&#xff0c;发现原先选择并不优或达不到目标&#xff0c;…

c++编码风格指南_100%正确的编码样式指南

c编码风格指南Here are three links worth your time:这是三个值得您花费时间的链接&#xff1a; The 100% correct coding style guide (4 minute read) 100&#xff05;正确的编码样式指南( 阅读4分钟 ) I wrote a programming language. Here’s how you can, too (10 minu…

xp开机黑屏故障分析

今天装完xp系统之后&#xff0c;重启开机发现竟然黑屏了&#xff0c;查资料发现有很多用户在修改分辨率后&#xff0c;因显示器不支持修改后的分辨率&#xff0c;会出现电脑黑屏的情况。分辨率调高了&#xff0c;超出了屏幕的范围&#xff0c;肯定会黑屏&#xff0c;而且这个问…

应用程序图标_如何制作完美的应用程序图标

应用程序图标by Nabeena Mali通过Nabeena Mali 如何制作完美的应用程序图标 (How to Make the Perfect App Icon) With just 24 app icon slots on the first page of an iPhone home screen, or 28 if you have a fancy iPhone 7, creating the perfect app icon is a vital …

Luogu3702 SDOI2017 序列计数 矩阵DP

传送门 不考虑质数的条件&#xff0c;可以考虑到一个很明显的$DP:$设$f_{i,j}$表示选$i$个数&#xff0c;和$mod\ pj$的方案数&#xff0c;显然是可以矩阵优化$DP$的。 而且转移矩阵是循环矩阵&#xff0c;所以可以只用第一行的数字代替整个矩阵。当然了这道题$p \leq 100$矩阵…

java闰年的年份,Java案例-判断给定年份是闰年

专注学子高考志愿填报&#xff0c;分享你所不知道信息。Java案例-判断给定年份是闰年案例描述编写程序&#xff0c;判断给定的某个年份是否是闰年。闰年的判断规则如下&#xff1a;(1)若某个年份能被4整除但不能被100整除&#xff0c;则是闰年。(2)若某个年份能被400整除&#…

通过path绘制点击区域

通过path绘制点击区域 效果 源码 https://github.com/YouXianMing/Animations // // TapDrawImageView.h // TapDrawImageView // // Created by YouXianMing on 16/5/9. // Copyright © 2016年 YouXianMing. All rights reserved. //#import <UIKit/UIKit.h> #…

Raft与MongoDB复制集协议比较

在一文搞懂raft算法一文中&#xff0c;从raft论文出发&#xff0c;详细介绍了raft的工作流程以及对特殊情况的处理。但算法、协议这种偏抽象的东西&#xff0c;仅仅看论文还是比较难以掌握的&#xff0c;需要看看在工业界的具体实现。本文关注MongoDB是如何在复制集中使用raft协…