效率工具传送门

  • 推荐20套实战源码

  • 程序员你可以考虑安装的15款谷歌插件

  • 99%的人不知道搜索引擎的6个技巧

  • 12款好用的Visual Studio插件,最后一款良心推荐

有人问:规范的命名风格真的能让你程序员少出bug?
当遇到这方面的教训时,就会想到这句话还是有点道理的。
工作快三年多了,从刚开始的什么都不懂,到慢慢发现积累知识点的重要性。关于程序的命名规范之前也做过一些笔记,只是感觉不全面,就一直没有写出来。

直到前段时间看了邹溪源老师的这篇成就卓越代码,从关注细节开始
引发了我的感触,再不总结,都快2020年了,头发都掉了不少。

曾经刚工作的时候,命名也挺随意的,现在看起来,都有点想打过去的自己。总有这样的一个过程,有些知识点,在潜意识里并不知道要去了解深入它。

看看这些10中诡异的程序命名,你遇到几个?

文章目录

  • 01 措不及防的缩写
  • 02 中文命名
  • 03 自己的姓名来命名类和方法
  • 04 加了魔幻的方法命名
  • 05 歧义的命名
  • 06 数字化的命名
  • 07 考验眼神的命名
  • 08 直接以类型来命名
  • 09 不规范的方法名
  • 10 单词拼错的命名

01 措不及防的缩写

一般来说如果单词过长的话,会采用缩写的方式,比如number 》num
CurrentUser>currUser。可是工作中,经常会遇到这种“便秘式”命名,给人一种措不及防的感觉。有时候还要利用想象的空间的,猜一下这个命名到底是个什么玩意。
写完整的算了,他不他偏要来个缩写,缩写后,我就看不懂(本身就不长,干就万事了。)
这是一段xaml引入命名空间的代码,一个6个字符,缩写后成功地变成5个字符,最终为大家节省了点击一个键的卡路里。common完美缩写成comon

xmlns:comon="clr-namespace:SGS.SIO.Common.Utilities;assembly=SGS.SIO.Common"

建议:缩写干脆点,实在想不到好的缩写,那就直接写完整的单词

02 中文命名

(ps:无法展示类似代码.png)不要觉得中文命名不可思议,我以前也是这样觉得居然还有中文命名的,上一家公司就有这样的例子。工作一段时间后,你可能会遇到一些几年前甚至十年前的代码,什么是工作啊?工作嘛…
每一种存在,都有他的存在的理由(ps:不管是好还是坏)。我的思考是,上一家公司采用中文命名是有一定的原因的,那些名词如果英文来翻译的话,非常容易歧义、难以理解、甚至跑偏,工作嘛,不能改变的时候,就只能去接受它。
建议:不要使用中文命名,万不得已的情况下也不要,打上注释也行啊

03 自己的姓名来命名类和方法

这一case来自邹溪源老师文章成就卓越代码,从关注细节开始的第一段落
用自己姓名来命名,我是真没遇到过,邹老师是一位80后程序员,见多识广。所以碰到过这样case,我就分享一下

/// <summary>
/// author:zhangsan
/// </summary>
class ZhangsanTest
{private void TestGetData(){int a, b, c;}private int ZhangsanGet(int s1, int s2){int s3 = s1 + s2;return s3;} private List<string> GetData(){return null;}
}

这是一个喜欢用自己的姓名来命名类和方法的作者,在他的代码中,经常可以看到这样奇怪的对象定义,而且他还喜欢用a,b,c,d,e,f或者s1,s2这样的命名,仿佛他的代码自带混淆特效。这样的代码嗅起来会不会觉得充斥着奇怪的味道?

建议:名字来命名这事儿挺严肃的,毕竟后面接手的人可能会认识你这个沙雕

04 加了魔幻的方法命名

    private void GetData(){int a, b, c;}

这个我是真的见过,看到邹老师分享,我抽了根烟,相见恨晚.png。

另外,有没有发现有许多开发者喜欢用 GetData() 来定义获取数据的方法?然后这个方法就成为一个万金油的方法,不管是爬虫采集、或者数据绑定,无论是 C# 写的后端或者 Java 写的后端代码,或者用 vue 写的前端代码,仿佛在任何场景、任何数据应用都可以看到这样的方法。
如果一个项目中,有十几个地方都出现了这个** GetData() **方法,那种感觉一定非常难受

熟悉的名字,却是千变万幻的味道。
建议:这不是写那个GetData的码农吗?你品,你细品!

05 歧义的命名

这也是我遇到的真实案例,为此付出了无意义的1个小时调试。将一个页面的命名成this,可能觉得this好用,this挺喜欢好用。
比如这个:

x:Name="this"

调用的时候

Command="{Binding Source={x:Reference this},Path=BindingContext.EditCmd}"

当时就有点懵逼,这个this到底指的是什么。这种以关键字来命名的,估计是想报复同事。
良好的命名如这样的:

<CheckBox x:Name="chkBoxChinese" /> <Label Text="chinese"><Label.Triggers><DataTrigger TargetType="Label" Binding="{Binding Source={x:Reference chkBoxChinese}, Path=IsChecked}" Value="true"> <Setter Property="FontAttributes" Value="Italic, Bold" /> <Setter Property="FontSize" Value="Large" /> </DataTrigger> </Label.Triggers> </Label>

建议:禁止使用关键字来命名

06 数字化的命名

不要觉得,这事我最多也就上学时候干过。
全面发展,数字一体化。的却挺全面,曾经做xamarin的时候,在一个activity的里面有5,6个按钮,点了一个其他按钮显示不同状态,于是每个按钮变成dialog1、dialog2、dialog3
建议:根据实际的作用进行命名。

07 考验眼神的命名

int materialFirstNum = 8;
int materialSecondNum = 11;
int materialSumNum = materialFirstNum + materialSecondNum ;

欢迎大家来找茬,良好的命名变量是让人一看就明白,顾名思义。把不同的部分写在中间,书写时容易了,但是不容易检查。(ps:这里指的书写容易指的是写material时,各种IDE会有提示)
比如这样:

int firstMaterialNum = 8;
int secondMaterialNum = 11;
int sumMaterialNum = firstMaterialNum + secondMaterialNum ;

建议:如果有相似的名字,请把他们不同的部分卸载开头,其次是结尾。

08 直接以类型来命名

List<MaterialModel> list =new  List<MaterialModel>();
string[] array = { "","",""};

这种名字不好的地方有两个

  • 命名根本就不知道代表什么意思,毫无意义
  • IDE提示也容易混淆,不容易输入
    有经验的程序员肯定会写出这个变量是代表什么意思的,比如这样的
List<MaterialModel> materialList =new  List<MaterialModel>();
string[] titleIdArray = { "","",""};

建议:不要写与系统定义类型关键字的命名,命名要有意义。

09 不规范的方法名

比如这个命名:

public static int TwoNumSubtraction(int firstNum,int secondNum){return firstNum - secondNum;
}

最好改成 动词+名词格式,subtraction的缩写sub,这样的好处是合适的缩写顾名思义,SubTwoNum就知道是做两个数的减法运算。

public static int SubTwoNum(int firstNum,int secondNum){return firstNum - secondNum;
}

建议:方法名最好动词+名词格式

10 单词拼错的命名

SendMassage(…)看到这个,我感觉当时这哥们应该压力挺大的。
data和date 组合拳式混写,可能当时这个当事人自己也写蒙了吧!
form、from 。这个我也曾经常容易写错,傻傻分不清!
dataOne, dataTwo, dataThree, DataFour (手动捂脸)
建议:这个我真啥建议的…

结语:林子大了,什么鸟都有!最后问一句,什么是工作啊?
下篇会写到,代码命名方式有哪些?代码规范会写成一个系列

作者信息
【文章信息】:作者-张林:原文链接-https://blog.csdn.net/kebi007/article/details/103759171
【原创公众号】:dotNet全栈开发。文章目录
版权声明:本文为CSDN博主「dotNet全栈开发」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。

程序员:这10种糟糕的程序命名,你遇到过几个?相关推荐

  1. 完美程序员的10种品质

    导读:谁是完美程序员?著名博客作家Alex Iskold在<明星软件工程师的10种特质>一文中给出这个问题的答案: 1. 热爱编程 2. 完成事情 3. 持续重构代码 4. 使用设计模式 ...

  2. [置顶] 完美程序员的10种品质

    完美程序员的10种品质 转载自:http://zhousir.net/ 谁是完美程序员?著名博客作家Alex Iskold在<明星软件工程师的10种特质>一文中给出这个问题的答案: 1. ...

  3. 第 14 章 程序员常用 10 种算法

    第 14 章 程序员常用 10 种算法 1.二分查找算法 1.1.二分查找算法介绍 前面我们讲过了二分查找算法,是使用递归的方式,下面我们讲解二分查找算法的非递归方式 二分查找法只适用于从有序的数列中 ...

  4. web开发程序员有几种_每个程序员都应该知道的10种流行的Web开发工具

    web开发程序员有几种 Are you planning to get into web development? Take a tool with you, it's scary out there ...

  5. 能立刻激怒程序员的10句逗逼话==程序员的笑话

    都说程序猿不健谈,大号闷骚.抱歉,让你成天对着电脑一坐坐一天试试?程序猿人没问题,有问题的是这个职业.一上班有时间聊天交流的,放心,十有八九不是搞IT的,就算是搞IT的,那也是高管.一整天除了解决内急 ...

  6. 数据结构和算法-14.程序员常用10种算法

    1. 二分查找算法(非递归) 1.1 介绍 二分查找算法只适用于从有序的数列种进行查找,将数列排序后再进行查找 二分查找法的运行时间为对数时间O(log2 n),即查找到需要的目标位置最多只需要log ...

  7. 算法与数据结构学习(58)-程序员常用10种算法(佛洛依德算法)

    弗洛伊德(Floyd)算法介绍 和Dijkstra算法一样,弗洛伊德(Floyd)算法也是一种用于寻找给定的加权图中顶点间最短路径的算法.该算法名称以创始人之一.1978年图灵奖获得者.斯坦福大学计算 ...

  8. 程序员中前10%,我认识的这些老司机是怎么突破年薪百万

    随着这两年,社交圈的扩大,也让我逐渐认识到了越来越多的年薪百万的资深程序员,也刷新了我过去无知的认知.他们其实非常低调,鲜有对外吹嘘自己收入,一直兢兢业业的在技术上驰骋人生,当然,这样的人已经是程序员 ...

  9. 禅道程序员的10条原则--转载--为了不忘

    禅道程序员的10条原则 作者: Christian  来源: 伯乐在线  发布时间: 2012-04-23 22:52  阅读: 2802 次  原文链接   全屏阅读  [收藏]   英文原文:Th ...

最新文章

  1. 先出报表还是先计提所得税_大征期来啦!5分钟熟练掌握企业所得税申报
  2. Microsoft Visual Studio 2005 Beta 2 下载地址
  3. 如何正确对待vb脚本里的session
  4. linux2.6.37内核接两个硬盘导致读写效率变低的问题
  5. 评分卡模型剖析之一(woe、IV、ROC、信息熵)
  6. 如果Laravel 报错 file_put_contents(): failed to open stream
  7. Yii Framework2.0开发教程(5)数据库mysql性能
  8. CSS3中的动画效果记录
  9. 老师说过链表是分水岭,至少得会这些题目
  10. axure 元件_在Axure中实现波纹点击特效按钮的方法
  11. MySQL数据库进阶(事务Transaction)
  12. KubeSphere对于已经部署的服务进行修改后重新进行部署
  13. 男生看女生叫审美,女生看男生叫好色之新解
  14. 面向项目(七)—— C/C++的兼容性
  15. n-Track Studio Suite 9 Mac(多轨音乐制作工具)
  16. 【JZOJ4762】【NOIP2016提高A组模拟9.7】千帆渡
  17. MPCCI3.0.5\
  18. 怎么在WORD中输入10以上的带圈数字,看这里,10以上的带圈数字如何输入到WORD中
  19. 域名dns解析IP 与 本机IP 不匹配 是否继续安装
  20. python输入一个分数、约分后输出_Python中分数的相关使用教程

热门文章

  1. 澳洲艺术留学申请要求及流程是什么呢?
  2. Mob开放日:成功手游基因大揭秘
  3. 合合信息新推出反光消除技术,助力手写文字识别更精准
  4. 从市梦率到市盈率:“团跑跑”跑回互联网
  5. window开机自动运行python脚本
  6. Java+Selenium框架: 如何在日历中选择日期
  7. jQuery SuperSlide插件制作72个种常用的网页特效
  8. React拾遗:从10种现在流行的 CSS 解决方案谈谈我的最爱 (下)
  9. 爱彼迎发布父亲节全球热门户外房源榜单 | 美通社头条
  10. DTLS-SRTP协议学习