首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JS进阶系列01-JS的弱类型和动态类型

JS进阶系列01-JS的弱类型和动态类型

作者头像
love丁酥酥
发布2018-08-27 15:58:55
2.2K0
发布2018-08-27 15:58:55
举报
文章被收录于专栏:coding for lovecoding for love

1. 弱类型,强类型,动态类型,静态类型的区别

首先,我们要弄清楚编程语言的两组划分,即弱类型和强类型,动态类型和静态类型。下面有一幅图,非常详细地说明了它们各自的定义和区别。

动态/静态,强类型/弱类型-转

该图转自编程语言傻傻分不清:弱类型、强类型、动态类型、静态类型一文,大家可以前往该文章查看编程语言这两组划分的详细定义和区别。

2. JS的弱类型和动态类型

JS种有5种基本数据类型:Undefined,Null,Boolean,Number和String,以及一种复杂数据类型Object。但JS的变量在声明时无需指定其类型,而是统一使用var关键字。并且在其声明之后,我们可以为其随便赋值不同的类型。 JS由于不需要关注变量的类型,可以使代码更加简洁,也能使开发者集中更多的精力在处理业务逻辑之上。但由于其无法保证变量类型,从而在程序运行期可能发生跟类型相关的错误。 比如:

var s = 1;
s();  //Uncaught TypeError: s is not a function

而这样的错误对于JAVA在编译期间就会检查出来。

3. JS鸭子类型的思想

(这一节的内容大家可以直接看BOOK-《JavaScript设计模式与开发实践》 第一部分)

JS对变量类型的宽容给实际编码带来了很大的灵活性,由于无需进行类型检测,开发者可以尝试调用任意对象的任意方法,而无须去考虑它原本是否被设计为拥有该方法。

这一切都建立在鸭子类型(duck typing)的概念上。鸭子类型的通俗说法是:“如果它走起路来像鸭子,叫起来也是鸭子,那么它就是鸭子。”

有个很形象的例子:

从前在Javascript王国里,有一个国王,他觉得世界上最美妙的声音就是鸭子的叫声,于是国王召集大臣,要组建一个1000只鸭子组成的合唱团。大臣们找遍了全国终于找到999只鸭子,但是始终还差一只,最后大臣发现一直特别的鸡,它的叫声跟鸭子一模一样,于是这只鸡就成为了合唱团的最后一员。

这个故事告诉我们,国王要听的只是鸭子的叫声,这个声音的主人到底是一个鸡还是要鸭子并不重要。鸭子类型指导我们只关注对象的行为,而不关注对象本身,也就是关注HAS-A(拥有什么),而不是IS-A(是什么)。

下面我们用代码模拟这个故事:

var duck={
    duckSinging:function(){
        console.log("噶嘎嘎");
    }
};
var chicken={
    duckSinging: function () {
        console.log("噶嘎嘎");
    }
};
var choir=[]; //合唱团
var joinChoir=function(animal){
    if(animal&&typeof animal.duckSinging==='function'){
        choir.push(animal);
        console.log("恭喜加入合唱团");
        console.log("合唱团已有成员:"+choir.length);
    }
};
joinChoir(duck);
joinChoir(chicken);

我们看到,对于加入合唱团的动物,大臣们根本无需检查它们的类型,而是只需要保证它们拥有duckSinging方法。如果下次期望加入合唱团的是一只小狗,而这只小狗刚好也会鸭子叫,我相信这只小狗也能顺利加入。

在动态类型语言的面向对象设计中。鸭子类型的概念至关重要。利用鸭子类型的思想,我们不必借助超类型的帮助,就能轻松地在动态类型语言中实现一个原则:“面向接口编程,而不是面向实现编程”。例如,一个对象若有push和pop方法,并且这些方法提供了正确的实现,它就可以被用来当作栈使用。一个对象如果有了length属性,也可以依照下标来存取属性(最好还要拥有slice和splice等方法),这个对象就可以被当做数组来使用。

参考

编程语言傻傻分不清:弱类型、强类型、动态类型、静态类型 BOOK-《JavaScript设计模式与开发实践》 第一部分

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.03.25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 弱类型,强类型,动态类型,静态类型的区别
  • 2. JS的弱类型和动态类型
  • 3. JS鸭子类型的思想
  • 参考
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档