论证是一门学问

本文的标题借用了安东尼.韦斯顿(Anthony Weston)的《论证是一门学问》一书的标题,向安东尼老爷子致敬的同时,也希望更多人能够真正了解“什么是论证”。 

 

争论与论证从来都不是新鲜事物,作为软件行业的科技工作者,理应对各种论证的手段了如指掌才是。然而,从各种我参与的有争论的场合来看,事实并非如此。许多论证最终都停在口号式的结论,或是由于自说自话无法进行下去。科学对人类的贡献之一在于科学的方法,而“合理”的论证方式才是科学真理得以彰显的手段。

 

《论证是一门学问》一书(http://book.douban.com/subject/5399343/)中提到了论证的基本规则,以及各种论证的方式:类比论证、因果论证、演绎论证。这些方法都不是什么难度很高的方法,但在实际的争论过程中,尤其是在微博上进行的论证中(字数的限制也是导致误解的原因之一),却并不经常被论证的双方所遵守。

 

一个观点包含“前提”和“结论”。前提是为你的结论提供理由的表述。前提一般基于具体的事实或是已经被事实证实的结论,通过前提,借助各种论证的方法就能推导出结论。这个过程看似简单,在很多情况下却并非显而易见。《论证是一门学问》一书的第3页给出了《福尔摩斯全集》中的《银色白额马》中福尔摩斯的一个推论过程:

 

马厩里养着一条狗,然而,尽管有人进入马厩并牵走一匹马,(这条狗)却没有叫……显然,……来者是这条狗相当熟悉的一个人。

 

在这个推论中,福尔摩斯有两个前提。一个显而易见的前提是,狗没有冲着来人叫;另外,福尔摩斯使用了一个他认为我们都会认可的前提:狗会冲着陌生人叫。这两个前提合起来,便能够得出他的结论:来人是狗熟悉的人。

 

接下来我们用几个更贴近各位工作实际的例子来展示不合理的推论过程。

 

例1:

软件测试工程师懂得开发后,会从开发的角度思考问题。这样测试工程师就不能起到与开发工程师在思路上互相补充的效果了。

 

这个推论过程是一个典型的假言三段论(Hypothetical syllogism,见《论证是一门学问》P80),这里的要点是,只有在连续的两个推论都都没有问题的情况下,最后的结论才是有效的。这里的两个推论分别是:1,如果软件测试工程师懂得开发,就会从开发的角度考虑问题;2,如果测试工程师从开发的角度考虑问题,就无法起到与开发工程师在思路上互相补充的效果。

 

显然,对第一个推论,其要害在于,是否一个人懂得了某种思考方式,就一定会应用这种思考方式?答案显然是否。很容易用反例方法推翻这个推论:成人通常也可以懂得儿童的思维方式,但这并不意味着他一定会用儿童的思维方式去思考问题。实际生活中,大多数父母都能够在懂得儿童思考问题的同时用成人的思考方式考虑问题。

 

因此,由于第一个推论就不成立,最终的结论显然不可靠。

 

例2:

很多组织甚至认为独立的测试团队是不需要的,这种观点是错误的!他们认为测试不重要是因为他们对质量不重视!。

 

这里的前提有两个:1,很多组织认为独立测试团队是不重要的;2,这些认为独立测试团队不重要的组织不重视质量。很显然,稍微深入一点探讨这个结论,就很容易发现,“很多”这个前提没有数据来源,可能仅仅是推论者的一个主观感觉;另外,由于“很多组织”本身就是一个虚拟出来的概念,更谈不上有任何实例来说明“很多组织”中的这些都是对质量不重视的公司。反而,针对这个论断,容易举出好些反例来证明它是不可靠的(大多数互联网创业公司都会在很长一段时间内不设置独立的测试团队)。

 

关于例1和例2提到的话题,我并不想在这里进行讨论。拿它们做例子,不过是说明一个有效的论证应该是什么样子的。

 

论证中,一方面需要为自己的观点提供可靠的前提,提供合理的逻辑推断过程,同时也需要对自己不认同的观点提出置疑和反驳。与众不同的观点并不可怕,可怕的是无法以符合逻辑的方式捍卫自己的观点。

 

当对自己不认同的观点提出置疑的时候,反例是最简单的方式。但要举出反例,必须清楚的了解对方观点的定义。由于所有观点就是基于前提(事实)和推理过程的,证明对方的前提的不正确性,或是证明对方的推理过程的不正确性同样奏效。例如,有以下观点:

例3:

Google的测试工程师与开发工程师的比例是1:10,因此只需要少数的测试工程师就能做好测试工作。

 

这里的前提有三个:第一个是显而易见的前提,“Google测试工程师与开发工程师的比例是1:10”;第二个是隐含的“Google的测试工作做的很好”;第三个前提隐藏得更深,“Google的测试工作完全是由测试工程师来做的”。这三个前提中的任何一个不成立都会导致这个结论不成立。在我看来,最容易被击倒的是第三个前提(“Google的测试工作完全是由测试工程师来做的”),实际上,这个在Google内完全不成立。但有趣的是,相当多的对这个观点的辩驳都集中在第一个和第二个前提上。

 

例4:

Google的X项目的工程师共有15名,其中测试工程师4名,因此Google所谓的开发与测试人员的比例是1:10是不真实的。

 

很显然,这个论断根本就偷换了要反驳的结论。“Google的开发与测试工程师比例是1:10”并不等于“在所有Google的项目中开发与测试的比例都是1:10”。因此,要推翻这个前提,其实最简单的方法是拿到Google的开发工程师与测试工程师的总人数比例。

 

例5:

Google的产品经常出现bug,因此Google的测试做的并不好。这些不好都是由于Google的测试工程师太少造成的。

可靠的前提才能建立可靠的结论。说Google的产品经常出现bug,最好拿出相应的数据。这方面James A. Whittaker显然就老练得多,这哥们在自己blog的为什么要离开google的文章中用了一些他自己的感知数据证明这一点。不过即使这样,Whittaker也没有说“google的测试做的不好”,原因是“好”与“不好”根本就没有数字上的标准,bug数多少叫做好?bug的影响范围(人数)与造成的失效成本要不要计算?这个推论的第二个部分则更是“冲动论证”的典型。它同样隐含了两个前提:1,在google中,发现缺陷是测试工程师的职责;2,测试工程师数量的多少与产品中遗留缺陷的数量呈负相关。可惜的是,这两个前提都不能够成立。

 

啰嗦了一堆文字,也给出了一些我自己能看到和听到的不合理的论证,不过,这篇文章的用意并不是想在这些例子涉及到的问题上挑起争端,而只是希望大家都能够用更好的论证方式捍卫自己的观点,以及看待别人的观点。

 

我经历过和了解到的中国的学校(大学、中学、小学均如此),大多都不太在意对学生论证能力的培养,作为这个体制中被培养出来的一员,我在很长时间内一直没有掌握正确的论证方法。但随着工作中的体验越来越多,接触到了越来越多的优秀同事,才发现自己身上缺少的这种论证方法的确会影响到自己的发展和工作。鉴于此,我希望通过本文,能够让更多的工程师,尤其是测试工程师了解到论证的方法,希望有更多人能从论证中找到棋逢对手的乐趣。

  

转载于:https://www.cnblogs.com/guanhe/archive/2012/08/21/2650039.html

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

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

相关文章

[翻译]SQL Server 工作集消息

Q:我发现有指向工作集(SQL Server保留内存区域)被分页出来相关的消息: 重要部分的 SQL 服务器进程内存已被分页。这可能导致性能下降。持续时间: 0 秒。 工作集 (KB): 2484,已提交 (KB): 48036&…

Redis源码分析之工具类util

在redis源码中的辅助工具类中,主要包括大小端转换、SHA算法以及util.h中对应的算法。 大小端转换: LittleEndian:低位字节数据存放于低地址,高位字节数据存放于高地址。 BigEndian:低位字节数据存放于高地址&#x…

Linux下如何安装软件

一、解析Linux应用软件安装包通常Linux应用软件的安装包有三种:1) tar包,如software-1.2.3-1.tar.gz。它是使用UNIX系统的打包工具tar打包的。2) rpm包,如software-1.2.3-1.i386.rpm。它是RedHat Linux提供的一种包封装…

Python深浅拷贝辨析

1 import copy2 3 list1 [11, 22, [33, 44]]4 list2 list15 list3 list1[:]6 list4 copy.copy(list1)7 list5 copy.deepcopy(list1)8 9 list1[0] 0 # 对列表的首层做增删改查操作 10 print("list1:",id(list1),list1) # list1: 1455502266696 [0, 22, […

生活规则

1.朋友请你吃饭,不要觉得理所当然,请礼尚往来,否则你的名声会越来越臭。 2.给自己定目标,一年,两年,五年,也许你出生不如别人好,通过努力,往往可以改变70%的命运。破罐子…

[AX]AX2012 SSRS报表使用Report Data Method

在AX2012的SSRS报表中可以使用c#或者Visual basic .net编写report data method来获取和操作数据,由report data method返回的数据可以用在报表的表达式中,也可以用作dataset的数据源。 使用Report data method首先需要创建AX model工程,在工程…

HIVE和HBASE区别

转载:https://www.cnblogs.com/justinzhang/p/4273470.html 1. 两者分别是什么? Apache Hive是一个构建在Hadoop基础设施之上的数据仓库。通过Hive可以使用HQL语言查询存放在HDFS上的数据。HQL是一种类SQL语言,这种语言最终被转化为Map/Re…

php调试

今天在使用php 的session 的时候,出现了以前就遇见但是又解决不了的问题,在页面上出现如下提示: Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent (output started at E:\php…

C 结构体

C 结构体C 数组允许定义可存储相同类型数据项的变量,结构是 C 编程中另一种用户自定义的可用的数据类型,它允许您存储不同类型的数据项。结构用于表示一条记录,假设您想要跟踪图书馆中书本的动态,您可能需要跟踪每本书的下列属性&…

lightoj1259 线性筛的另一种写法 v变成bool标记数组

也是用线性筛&#xff0c;但是v用int会爆&#xff0c;所以这个线性筛用的是另外一种写法 #include<cstdio> #include<cmath> #include<queue> #include<vector> #include<cstring> #include<iostream> #include<algorithm> using na…

Redis基数统计之HyperLogLog小内存大用处

转载&#xff1a;https://blog.csdn.net/azhegps/article/details/71158952 我们一直都知道&#xff0c;redis几大常用数据结构&#xff0c;字符串、散列、列表、集合、有序集合。其实后来Redis做了很多补充&#xff0c;其中之一就是HyperLogLog&#xff0c;另外的还有GEO&…

matlab中的qr函数

转自&#xff1a;https://blog.csdn.net/qq278672818/article/details/62038630 实数矩阵A的QR分解是把A分解为A QR这里的Q是正交矩阵&#xff08;意味着QTQ I&#xff09;而R是上三角矩阵。类似的&#xff0c;我们可以定义A的QL, RQ和LQ分解。更一般的说&#xff0c;我们可以…

(String) 和 String.valueOf() 两种字符串转换的区别

使用 String.valueOf() 进行数据转换&#xff0c;如果被转换的数据为 null, 则这种方法将返回一个 "null" 字符串 &#xff08;String&#xff09; 方法进行转换时&#xff0c;如果被转换的数据为 null, 则返回 null 对象而不是一个 "null" 字符串。转载于…

利用有名管道实现进程间的通信

1 /*****************************************************************2 * Copyright (C) 2018 FBI WARNING. All rights reserved.3 * 4 * 文件名称&#xff1a;fifo_write.c5 * 创 建 者&#xff1a;constantine6 * 创建日期&#xff1a;2018年02月26日7 * 描 …

为什么分布式一定要有redis,redis的一些优缺点

1、为什么使用redis 分析:博主觉得在项目中使用redis&#xff0c;主要是从两个角度去考虑:性能和并发。当然&#xff0c;redis还具备可以做分布式锁等其他功能&#xff0c;但是如果只是为了分布式锁这些其他功能&#xff0c;完全还有其他中间件(如zookpeer等)代替&#xff0c;…

Google protobuf使用技巧和经验

Google protobuf是非常出色的开源工具&#xff0c;在项目中可以用它来作为服务间数据交互的接口&#xff0c;例如rpc服务、数据文件传输等。protobuf为proto文件中定义的对象提供了标准的序列化和反序列化方法&#xff0c;可以很方便的对pb对象进行各种解析和转换。以下是我总结…

show部分书...

继续购入中 转载于:https://www.cnblogs.com/Clingingboy/archive/2009/06/09/1499816.html

linux 中用PPA安装软件

一般来说 PPA 提供了三条命令&#xff0c;如下面的命令&#xff1a; sudo apt-get sudo apt-get update sudo apt-get install 其中&#xff0c;第一行的代码后面加上 获得安装软件的地址 第二行为更新系统源地址 第三行为安装软件

HTTP_POST———使用mysql_udf与curl库完成http_post通信模块(mysql_udf,multi_curl,http,post)...

HTTP_POST———使用mysql_udf与curl库完成http_post通信模块&#xff08;mysql_udf,multi_curl,http,post&#xff09; 这个模块其目前主要用于xoyo江湖的sns与kingsoft_xoyo自主研发的TCSQL数据库做数据同步&#xff0c;当有feed插入sns数据库&#xff0c;使用触 发器调用该模…

LSM树存储模型

LSM&#xff08;log-structed-merge-tree&#xff09; leveldb和rocksdb底层使用LSM树做存储引擎&#xff0c;LSM树使用skiplist做索引&#xff0c;他们先将数据写入内存中&#xff0c;按照key进行划分&#xff0c;定期的merge写入到磁盘中&#xff0c;合并后数据写入下一层le…