如何当上Leader和六千个bug的系统
在昨天的读书会上我分享了我是如何当上leader以及当上leader之后的体会。然后今天Sophie总结了我的发言,大家对此有些反馈。我根据大家的反馈写了这篇文章,主要针对几点:
- 大家如何当上leader?
- 关于那六千多个bug的系统。
- 关于其他人也来抢leader这个position.
在我简单描述提前一年布局当上leader的经过之后。可能大家会觉得我so lucky, 没有什么借鉴意义.
所以我在这里剥离出运气的成分, 用科学(数学)的角度来进行剖析, 希望对大家会有帮助.
数学中有一门学科叫概率论与数理统计, 里面有个贝叶斯概率(理论\方法).
贝叶斯概率承认运气的存在, 认为这个世界上没有100%的概率,所有人想要做成事,都需要一点点运气。
贝叶斯概率在承认运气的前提下, 通过科学的方法(数学)让你成功的概率能够接近100%。
贝叶斯(概率论与数理统计)是一门数学,我的运气大家不能复制,但是数学却是可以给大家复制的,毕竟数学最大的特点就是在我这里1+2=3,到了你那里1+2依旧是会等于3, 无论哪个国家哪个语言哪种性别, 数学都是通用和可复制的。
所以我认为它能够帮助到大家当上leader. 在后面我会介绍相关的一本书和一篇文章给大家.
第二点就是关于那六千多个bug还能得到客户认可的系统.
有些人会想, 几百个bug的系统都得不到客户的认可, 那六千多个bug的系统是如何得到客户认可的呢?
首先, 根据贝叶斯概率, 0 bug系统是不存在的, 系统只能够无限的接近0 bug, 但是永远不可能达到0 bug.
其次, 几千上万个bug的并且被大家认可的系统和产品不少, 比如windows, office都是, 我在2007年给微软提了一个outlook中文版的bug, 很多年了都还没有修复.
那么, 为什么windows和office存在几千上万个bug都能被大家认可, 而一些几百个bug的系统却不被认可呢?
答案是只要符合贝叶斯函数即可. 以下是书里的一段:
尽管你已是一个编程老手,但bug仍有可能在代码中存在。于是,在实现了一段特别难的算法之后,你决定先来一个简单的测试用例。这个用例通过了。接着你用了一个稍微复杂的测试用例。再次通过了。接下来更难的测试用例也通过了。这时,你开始觉得也许这段代码已经没有bug了。
如果你这样想,那么恭喜你:你已经在用贝叶斯的方式思考!简单地说,贝叶斯推断是通过新得到的证据不断地更新你的信念。贝叶斯推断很少会做出绝对的判断,但可以做出非常可信的判断。在上面的例子中,我们永远无法100%肯定我们的代码是无缺陷的,除非我们测试每一种可能出现的情形,这在实践中几乎不可能。但是,我们可以对代码进行大量的测试,如果每一次测试都通过了,我们更有把握觉得这段代码是没问题的。贝叶斯推断的工作方式就在这里:我们会随着新的证据不断更新之前的信念,但很少做出绝对的判断,除非所有其他的可能都被一一排除。
在代码测试的例子中,如果你问频率函数:“我的代码通过了所有测试,它现在没有bug了吗?”频率函数会给出“yes”的回答。但如果你问贝叶斯函数:“通常我的代码有bug,现在我的代码通过了所有测试,它是不是没有bug了?”贝叶斯函数会给出非常不同的回答,它会给出“yes”和“no”的概率,例如“‘yes’的概率是80%,‘no’的概率是20%。”
这和频率函数返回的结果是非常不同的。注意到贝叶斯函数还有一个额外的信息——“通常的我的代码有bug”,这个参数就是先验信念。把这个参数加进去,贝叶斯函数会将我们的先验概率纳入考虑范围。通常这个参数是可省的,但我们将会发现缺省它会产生什么样的结果。
更详细的信息大家可以看《贝叶斯方法:概率编程与贝叶斯推断》这本书.
结论:
一个系统如果是经过贝叶斯方法测试的, 即使它存在几千上万个bug, 这个系统依然可以得到客户的认可.
一个系统如果没有经过贝叶斯方法测试的, 几百个bug对于这个系统是相当严重的啦.
第三点就是关于其他人也来抢leader这个position.
首先当然是其他人意识到leader这个position有利益了, 有利可图大家才会来争.
然后就是其他人觉得和我能力差不了多少, 他们能抢到我这个位置.
这里就”其他人觉得和我能力差不了多少, 他们能抢到我这个位置.”进行数学分析吧.
假设其他人成功抢到leader这个position的概率是80%, 我成功抢到leader这个position的概率是95%.
那么是否他们只要再努力一下就可以提高这15%概率的差距, 从而抢到leader这个position呢?
他们认为是的, 所以他们才来抢. 然而这是一个错觉, 从数学的角度来看, 差距很大, 这里我贴一个例子, 让大家看一下差距有多大.
假如一件事情成功的概率是20%,是不是就意味着,我重复做这件事5次,就一定能成功呢?
很多人会这样想,但事实并不是这样。
如果我们把95%的概率定义为成功,那么这件20%成功概率的事,你需要重复做14次。
换句话说,你只要把这件20%成功概率的事,重复做14次,你就有95%的概率能做成。
计算过程我放在这里,对公式头疼的小朋友可以直接略过。
做一次失败的概率为:1-20%=80%=0.8
重复做n次至少有一次成功的概率是95%,就相当于重复做n次每一次都不成功的概率是5%,
重复做n次都不成功:80%^n=1-95%=5%=0.05
n=log(0.8,0.05)=13.42
所以重复做13.42次,你成功的概率能达到95%。
如果你要达到99%的成功概率,那么你需要重复做21次。
以上例子出自<刘润对谈吴军:每个人都一定要有数学思维 >
希望会对大家有帮助,不过我更加希望得到大家新的反馈从而令彼此都得到进步。
如何当上Leader和六千个bug的系统的更多相关文章
- 9. SOFAJRaft源码分析— Follower如何通过Snapshot快速追上Leader日志?
前言 引入快照机制主要是为了解决两个问题: JRaft新节点加入后,如何快速追上最新的数据 Raft 节点出现故障重新启动后如何高效恢复到最新的数据 Snapshot 源码分析 生成 Raft 节点的 ...
- 为什么我会认为SAP是世界上最好用最牛逼的ERP系统,没有之一?
为什么我认为SAP是世界上最好用最牛逼的ERP系统,没有之一?玩过QAD.Tiptop.用友等产品,深深觉得SAP是贵的有道理! 一套好的ERP系统,不仅能够最大程度承接适配企业的管理和业务流程,在技 ...
- Apache shiro集群实现 (六)分布式集群系统下的高可用session解决方案---Session共享
Apache shiro集群实现 (一) shiro入门介绍 Apache shiro集群实现 (二) shiro 的INI配置 Apache shiro集群实现 (三)shiro身份认证(Shiro ...
- 谷歌修复了 FFmpeg 中上千个 bug
谷歌在科技业界中几乎每天都会创造出新闻素材,它的触手涉及到了生活中的多个领域.最近谷歌将其Google +社交网络与邮件服务Gmail相结合.然而今天谷歌宣布他们修复了FFmpeg的上千个bug. ...
- Android系统--输入系统(十六)APP跟输入系统建立联系_InputChannel和Connection
Android系统--输入系统(十六)APP跟输入系统建立联系_InputChannel和Connection 0. 核心:socketpair机制 1. 回顾Dispatch处理过程: 1.1 放入 ...
- 线上centos6出现软死锁 kernel:BUG: soft lockup
线上centos6出现软死锁 kernel:BUG: soft lockup 今天线上一台centos6机器用xshell一直连接不上,然后在xshell上显示 Message from syslog ...
- Lucene.net(4.8.0) 学习问题记录六:Lucene 的索引系统和搜索过程分析
前言:目前自己在做使用Lucene.net和PanGu分词实现全文检索的工作,不过自己是把别人做好的项目进行迁移.因为项目整体要迁移到ASP.NET Core 2.0版本,而Lucene使用的版本是3 ...
- 在ubuntu上搭建开发环境3---解决Y470一键系统重装之后恢复ubuntu引导启动的方法
2015/08/18 将知识.常用的操作整理出来一定要完整,注意细节. 就像下面是再2015.04.27时候整理的,当时确实实验成功了,但是可能忘记记下具体的细节,尤其是3.4.5.6步骤中的关于盘符 ...
- 在ubuntu上搭建开发环境2---Win7、Ubuntu双系统正确删除Ubuntu
这种删除ubuntu的方式就是针对本博客中搭建双系统的方式:http://www.cnblogs.com/xumenger/p/4459963.html 如果ubuntu不是以wubi方式安装的,那么 ...
随机推荐
- [debug] 解决在C++编写过程中的“找到一个或多个多重定义的符号”
如下图: 其在 common.h 中定义了一个变量a ,然后在两个 cpp 文件中都是用它. 在这种情况下,链接时就会出现 “找到一个或多个多重定义的符号”. 解决方案: 在某个cpp文件中定义,然后 ...
- RabbitMQ Node.js 示例
RabbitQM 处理和管理消息队列的中间人(broker).可简单理解为邮局,你在程序中写好消息,指定好收件人,剩下的事件就是 RabbitMQ 的工作了,它会保证收件人正确收到邮件. 任何发送邮件 ...
- concurrent.futures模块简单介绍(线程池,进程池)
一.基类Executor Executor类是ThreadPoolExecutor 和ProcessPoolExecutor 的基类.它为我们提供了如下方法: submit(fn, *args, ** ...
- mysql修改数据 -- 主键冲突
mysql 插入数据唯一键冲突 前提: 修改数据三种可用的方法解决主键冲突的问题 1. insert into ... on duplicate key update set ... 2. updat ...
- 接口测试基础--Fiddler、Postman、Python实现对接口的测试
写在前面:本文主要的章节规划: 1.什么是接口测试 另外,有的时候会直接调用别的公司的接口,比如银行的.淘宝的.支付宝的,此时也需要做接口测试以及验证数据: 做接口测试的好处: 其中, ...
- Threads(异步和多线程)
Task是.NET Framework4.5出现的,线程是基于线程池的,然后提供丰富的api,Thread方法很多很强大,但是太过强大,没有限制. DoSomethingLong方法如下: /// & ...
- HTML学习 day03
表单 表单 表单:表单域:包含了处理表单数据所用的程序的URL以及数据提交到服务器的方法. 表单控件:(对象.元素):包含了文本框.密码框.隐藏.多行文本框(文本域).复选框.单选框.下拉 ...
- 区块链社交APP协议分析预告
2017年,比特币的火热,直接导致了代币市场的繁荣: 2018年,作为信用体系的未来解决方案,区块链引发了互联网原住民的淘金热. 作为风口上的引流神器,区块链技术与社交网络结合起来,产生了一系列区块链 ...
- Android App自动更新解决方案(DownloadManager)
一开始,我们先向服务器请求数据获取版本 public ObservableField<VersionBean> appVersion = new ObservableField<&g ...
- Weblogic的三种部署方式
Weblogic的三种部署方式 在weblogic中部署项目通常有三种方式:第一,在控制台中安装部署:第二,将部署包放在domain域中autodeploy目录下部署:第三,使用域中配置文件c ...