刚写完排序算法,就被开除了…

简介:

据说是一个月薪 9K 的 Java 程序员,因老板让他写一个排序算法,然后他就写了一段屌炸天的休眠排序算法,接着他就被老板开除了……

排序算法代码大概是这样的:

3f03694823e9a2a4870d3ddaf7dbe007a56aae89

99a7657ec386990af074545e9d0de074cb1f5d00

这段代码有什么问题?

这个程序员更屌啊,数字排序,用一行简单的 Arrays.sort 就搞定的东西,他竟用到了这么多概念。

1、循环

2、线程休眠

3、多线程

下面贴上完整的代码:

/**
 * 微信公众号:Java技术栈
 */

public class ArraySort implements Runnable {

    private int number;

    public ArraySort(int number) {
        this.number = number;
    }

    public static void main(String[] args) {
        int[] numbers = new int[]{102338629132580666};
        for (int number : numbers) {
            new Thread(new ArraySort(number)).start();
        }
    }

    @Override
    public void run() {
        try {
            Thread.sleep(this.number);
            System.out.println(this.number);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

}

还好是数字小啊,还好休眠是毫秒啊,要是数字大,要是休眠时间是秒,那要等多少休眠时间才能排序完?

按道理,他的程序也没问题啊,老板为什么要开除他?应用程序中出 BUG 不是很正常的事吗?但他这种排序思维,能写出这样的隐藏 BUG 也是绝了,创造性的发明了 "休眠排序" 算法,系统里面还不知道有多少这样的坑,不开除他开除谁啊?

如果非要说一个原因,我感觉,这哥们是故意这么写的,造成查询速度较慢,之后下个迭代优化,查询速度瞬间提上来了,这可是为公司做出大贡献了,年底了,奖励个优秀个人奖.....

或许他应该看一下排序这篇文章:《改变计算技术的9个伟大算法》。

说到这个程序员,让我想起了最近审查代码时候的几个坑,真是让人哭笑不得。。。

示例1:

if(flag  == false){
    return true;
else {
    return false;
}

直接 return flag 不行?写这么绕,还把逻辑写错了。

示例2:

if(...)
    a
    b
    c

多段代码,if 不加 {},后面格式化成了:

if(...)
    a
b
c

这样导致业务逻辑有严重的 BUG,无语了吧?还有更多奇葩的.


原文发布时间为:2018-11-24

本文来自云栖社区合作伙伴“互联网架构师”,了解相关信息可以关注“互联网架构师”。


相关文章
|
7月前
17.【快速排序及三分取中优化详解】
17.【快速排序及三分取中优化详解】
36 0
|
26天前
|
搜索推荐 算法
【排序算法】一文教你从零学会希尔排序
【排序算法】一文教你从零学会希尔排序
|
算法 搜索推荐 测试技术
|
算法 搜索推荐 C++
<<算法很美>>——(三)十大排序算法(下)
<<算法很美>>——(三)十大排序算法(下)
<<算法很美>>——(三)十大排序算法(下)
|
存储 算法 搜索推荐
<<算法很美>>——(三)十大排序算法(上)(二)
<<算法很美>>——(三)十大排序算法(上)
<<算法很美>>——(三)十大排序算法(上)(二)
|
算法 搜索推荐 测试技术
<<算法很美>>——(三)十大排序算法(上)(一)
<<算法很美>>——(三)十大排序算法(上)
<<算法很美>>——(三)十大排序算法(上)(一)
|
算法
算法竞赛百日——快速排序 - 分治
算法竞赛百日——快速排序 - 分治
算法竞赛百日——快速排序 - 分治
|
算法 搜索推荐
# 每日一问——什么是快速排序?如何优化?
快速排序是从冒泡排序演变而来的算法,但是其比冒泡排序要高效,所以叫做快速排序,简单理解如下。
71 0
|
算法 搜索推荐
【排序算法】计数排序引发的围观风波——一种O(n)的排序
计算机课上,老师给一串数字6 1 6 9 9 1 4 2 1 5 8 8,问道:这一串数字,你们写个程序给我看,要求效率较高。学不出来的别下课了。
86 0
【排序算法】计数排序引发的围观风波——一种O(n)的排序