查看原文
其他

编码编成翔的十八般兵器

艾小仙 2021-05-21

The following article is from 四猿外 Author 四猿外

程序员最怕读别人的代码,比这个更可怕的是什么?

从别人那里接手一个老项目

前任程序员或者是编码能力不行,或者是跳槽之前故意摆烂……于是,一个隐藏着一堆烂摊子的项目,扔给了后来接手的人。

本来以前是代码里夹翔,后来就是翔夹代码了。

这些翔有各种各样的风味,其中就有那么十八种味道最是冲人。

1. 块里堆上我满满的翔

Java 中有着无数的语句块,这些语句块可以嵌套。于是我们有很多优秀的产翔大师会在这些语句块中不断地嵌套,犹如无数层的俄罗斯套娃。

2. 把翔藏在注释里,有时候它会“惊艳”了世界

有些哥们儿很鸡贼的把一些代码藏在注释里,这些代码可以随时成为定时炸弹。

public static void main(String[] args) {
  String a = "Hello";
  // \u000d a="world";
  System.out.println(a);
  // \u000a a="hello world!";
  System.out.println(a);
}

上面这段代码运行之后,说好的“Hello”呢?

world
hello world!

3. 我家大门常打开,欢迎错误走进来

在 Java 中,如果你想接手一个项目,看到一个父类的字段是非 private 的,而子类还存在同名字段,要注意了,这个项目的前任可能比较渣,你可能会恼火的想给他烧纸。比如:

public class Base {
  public int field = 0;

  public int getField() {
    return field;
  }
}
public class Sub extends Base {
  public int field = 1;

  public int getField() {
    return field;
  }
}

你这样测试下看看

public static void main(String[] args) {
  Sub s = new Sub();
  Base b = s;

  System.out.println(s.field);

  System.out.println(b.field);

  System.out.println(((Sub) b).field);

  System.out.println(((Base) s).field);
}

4. 我抓到了异常,但是我不想处理了,因为我要离职了

有些哥们儿走之前可能人未动心已远,也可能是懒的处理异常,他会给你留下一个谜之空白。

public class EmptyCatchBlockTest {
  public static void main(String[] args) {
    try {
      int a = 4, b = 0;
      int c = a/b;
    } catch(ArithmeticException ae) {
      // ???
    }
  }
}

对不起,兄弟,你留下这种薛定谔的处理是想让人帮你掀桌吗?

5. 只要我不考虑任何意外的情况,那么项目就一定会出意外

有些直性子的人,认为天下万物都可以直来直去,就好像直男只会让女生“多喝热水”一样。所以,他们写的代码非常直率,直接就不考虑意外情况。

  public static void main(String[] args) {
    int a = args.length;
    int b = 42 / a;

    if (a == 1) {
      a = a / (a - a);
    }
    if (a == 2) {
      int c[] = {1};
      c[42] = 99;
    }
}

上边的代码很直率,既不考虑 a 可能为 0 的情况,也不考虑数组越界。直来直去,就好像“我不尴尬,尴尬的就是别人”。

6. 我要把方法里可能的异常藏起来不告诉任何人

还有些哥们也不知道是不是有什么见不得人的事情,该抛出来的异常从来不抛出来,导致你根本不知道发生了什么事情。

InputStream is = null;
try {
  is = new FileInputStream("一个文件.txt");
catch (FileNotFoundException e) {

}

int b;
try {
  while ((b = is.read()) != -1) {
  }
catch (IOException e) {
  e.printStackTrace();
finally {
  try {
    is.close();
  } catch (IOException e) {
    e.printStackTrace();
  }
}

上面的代码里,如果文件找不到,接手人要撞墙的。

7. 我不走正道,因为我是个光荣的产翔侠

还有些人,不知道从哪里学会的邪门歪道,喜欢通过在捕获异常里写业务逻辑。对这种人,你九阴真经练成了梅超风啊。

public DateTime override Add(TimeSpan ts) {
  try {
    return base.Add(ts);
  }
  catch (ArgumentOutOfRangeException nb) {
    // calculate how much the MaxValue is exceeded
    // regular program flow
    TimeSpan saldo = ts - (base.MaxValue - this);
    return DateTime.MinValue.Add(saldo)
  }
  catch(Exception anyOther) {
    // 'real' exception handling.
  }
}

我就想问问,如果以异常来控制流程,那么如何在这些异常中寻找真正的异常情况?

8. 为了我走之前不出意外,我要捕获所有的 NPE

有些哥们儿会把 NPE 捕获住,恩,不解决问题,但是把提出问题的人给解决了。

private static void callInstanceMethodOfNull() {
  try {
    Integer age = null;
    age.toString();
  } catch (NullPointerException exception) {
    Logging.log(exception);
  } catch (Throwable exception) {
    Logging.log(exception, false);
  }
}

但是呢,这在正常的业务逻辑里很可能就把别人坑了,因为 Null 本身就是代表着一种非法状态。拿着前朝的剑斩今朝的官,包大人干的好啊。

9. 一个方法我如果写成一万行,公司一定会倒闭的

有些朋友可能有分离焦虑症,一个方法里能写上 1 万行代码。对不起,读书读几页都会犯困,读你这一万行代码……

10. 我要把所有业务逻辑都揉进几个类里,就好像女友第一次来我家

有些哥们,你看看他负责的项目,你发现整个项目没几个类。你很纳闷,觉得业务很复杂,竟然可以实现的如此简单吗?你再打开他的类看源码,哦豁,这就是个垃圾箱啊,什么都能往里塞啊。

哥们儿,这不是女朋友去你租的房子里,你为了显得干净,把你那些垃圾到处塞啊。

11. 是男人就来看我继承一百层类

有些爷爷不知道怎么想的,在他们眼里可能只有儿子和老子,一个类很不得搞一百层的类继承。你这样继承,您家万贯家财还能遭得住吗?

12. 如果我不用缓存,我就能多浪费公司的几台服务器

还有些哥们儿,明明知道他这个功能可能被频繁访问,比如登录的时候查相关的白名单、黑名单。哥儿们儿知道并发量大,可从来不想套个缓存,就是死从数据库里要数据。数据库想:生产队的驴也没我这么忙啊。

13. 线程安全?那是什么?能吃吗?

有些号称老程序员的老司机们,经年有余的不管线程安全。上来口吐异步同步,可是到手上了,线程就是个后娘养的,不管人家的数据安全了。合着身前叫人家小甜甜,落地了叫人家牛夫人了?

14. 在我手中无物不锁

还有些哥们儿,怕线程跟怕老婆一样,一旦可能多线程了,上来先上个同步锁。你打开他写的代码,十个方法十把锁。于谦儿这种大户人家也不带这样上锁的啊。

15. 我只知道 ArrayList,LinkedList 它配我用吗?

有些兄弟可能只知道 ArrayList 能放东西。就算需要动态调整的场景,哥们儿也从不考虑 LinkedList。系统慢的跟龟爬一样,愣是说系统遇到瓶颈。

16. 我的方法里有无数的参数,也许里面需要一个宇宙

有些程序大师,他需求可能比较多,性格比较贪婪。写的方法也跟性格一样邪恶,一个方法需要的参数,从天上到地下,什么都需要。你要调他的方法,就跟有个黑洞吸住你不放一样,陷进去你就出不来了。放我去飞好不好?

17. 递归里偷偷抹掉出口条件,就让服务器的 CPU 燃烧殆尽吧

有时候看到没有出口的递归方法,你就知道,写这段代码的人的人生是多么悲催,他悲惨的连测试都不敢,生怕碰伤了自己。没有出口的递归,就跟没有出路的人生一样。

18. 如果我不关闭资源,那么我就能让公司多花些内存钱

用了资源您不释放,您是嫌山上的笋不够采,下山来夺笋了吧。行行好,放了那个资源吧。

·················END·················



往期推荐

谈谈中台架构之交易中台|文末送书

阿里二面:什么是mmap?

一个单例还能写出花来吗?

谈谈写技术文章这个事情



您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存