语言:程序最终被表达为数据(结构)和逻辑(算法),命令式和说明式/函数式语言分别从这两方面分类;

动态:在语言陈述时无法确定,必须在计算机执行时才能确定语言关系;JS是完全动态语言,导致其不确定性一般包括:

  • 标识符确定:表现为动态类型,动态重写,动态存取数据结构;
  • 语句上下文确定:表现为动态变量/语法作用域,闭包作用域;

起源:

  • 动态数据类型:

    • 动态类型声明(动态类型绑定):语言变量是无类型的,只有在赋值后才有某种类型;
    • 动态空间分配(动态数据绑定):变量在赋值时才会分配空间;
  • 动态执行系统:
    • 编译器:将代码翻译成计算机可以理解的二进制代码;
    • 解释器:解释执行的语言系统,之后用一个执行环境读入并执行这份代码;
    • 动态执行系统一般依赖于解释和及时编译系统;目前JS一般采用虚拟执行环境+即使编译系统+语言引擎;

动态执行:   //动态执行系统分别动态加载和动态执行;JS中动态执行主要是eval()带来的效果;

动态方法调用:

  • JS中的执行体:

    • eval()函数入口指定的字符串,该字符串总是被作为当前函数上下文的语句来执行;
    • new Function()中传入的字符串,该字符串总是被作为一个全局,匿名函数闭包中的语句行被执行;
    • 执行体就是一个函数,通过()来执行;
  • 指定this对象: //call,apply,bind
    function calc_area(w, h) {
    console.log(w * h);
    }
    function Area() {
    this.name = 'MyOject';
    }
    Area.prototype.doCalc = function() {
    calc_area.apply(this,arguments);
    }
    var area = new Area();
    area.doCalc(10,20); //200
    Area.prototype.doCalc = function(v1) {
    var slice = Array.prototype.slice;
    calc_area.apply(this,[v1*2].concat(slice.call(arguments,1)))
    }
    area.doCalc(10,20); //400
  • 栈的可见与修改:
    function func_1() {};
    function func_2() {
    func_1.apply(this,arguments);
    }
    func_2();

    如上,在func_1.apply()被调用时,arguments被做了一次复制,值数值被复制,引用数据被创建引用,所以其实func_1与func_2中操作的arguments是两套数据;但是可以这样进行修改:

    function func_1() {
    arguments.callee.caller.arguments[0] = 100;
    }
  • bind() //bind方法绑定的函数做构造函数构造出来的对象即是绑定后的函数的实例,也是绑定前函数的实例;

重写://JS的重写是一个代码执行期的行为,语法分析期时引擎不会做任何预期或限制;其可能的问题是在运行期中会发现冲突或因为错误意外重写导致不可预料的代码逻辑错误;

  • 原型重写: //无法保证JS中,对象和其构造器必然存在某种相似性;其实重写原型已经违背了面向对象系统的基本原则;所以原型重写会导致同一个构造器可能有多套原型系统;
function MyOject_0() {}
var obj_1 = new MyOject_0(); MyOject_0.prototype = {
constructor: MyOject_0
}
var obj_2 = new MyOject_0(); console.log(obj_1 instanceof MyOject_0); //false
console.log(obj_2 instanceof MyOject_0); //true
  • 构造器重写:

    //执行期,重写变量
    function MyObject_2() {};
    var obj1 = new MyObject_2;
    MyObject_2 = function() {};
    var obj2 = new MyObject_2; console.log(obj2 instanceof MyObject_2); //true
    console.log(obj1 instanceof MyObject_2); //false //语法分析期,标示符覆盖
    function MyObject_3() {};
    var obj1 = new MyObject_3;
    function MyObject_3() {};
    var obj2 = new MyObject_3; console.log(obj2 instanceof MyObject_3); //true
    console.log(obj1 instanceof MyObject_3); //true

      

js:语言精髓笔记11--动态语言特性(1)的更多相关文章

  1. js:语言精髓笔记12--动态语言特性(2)

    对于括号内: 通过赋值时发生的重写: (Object1 = function() {}).prototype.value = 100; var obj1 = new Object1; console. ...

  2. js:语言精髓笔记7----原型继承

    面向对象有三个基本特性:封装,继承,多态:如果都满足的话称为面向对象语言:而部分满足则称为基于对象语言: 数据类型实现模型描述: JavaScript对象模型: 构造过程:函数->构造器 构造器 ...

  3. js:语言精髓笔记8--对象系统

    封装: 一把对象系统,封装是由语法解析来实现的,即语法作用域:但js是动态语言,因此只能依赖变量作用域: js的变量作用域只有表达式,函数,全局三种:所以js只能实现public和private两种封 ...

  4. Go语言学习笔记(一) [Go语言的HelloWorld]

    日期:2014年7月18日   1.简介     Go 编程语言是一个使得程序员更加有效率的开源项目.Go 是有表达力.简 洁.清晰和有效率的.它的并行机制使其很容易编写多核和网络应用,而新奇的类型系 ...

  5. C语言学习笔记一---C语言概述

    一.编程语言与解释语言 1.程序的执行 a.解释:借助一个能试图理解程序的程序,使计算机按要求执行你自己写的程序 b.编译:将所写程序翻译为机器语言写的程序,使计算机按要求执行你自己写的程序 2.两者 ...

  6. js:语言精髓笔记9--函数式语言特征

    形式化运算系统的研究: 图灵:提出图灵机形式系统,通过0,1运算系统来解决复杂问题: 冯诺依曼:提出了冯诺依曼体系:即通过修改内存反映运算结果: 阿隆左.丘奇:提出新的运算范型Lambda演算,计算机 ...

  7. js:语言精髓笔记5----语言分类

    计算模型:源于对计算过程的不同认识: 1.基于不同计算模型一般分为://教科书的一般分类 命令式语言: 函数式语言: 逻辑式语言: 面向对象程序设计语言: 2.基于程序本质分类:  //编程的经典法则 ...

  8. js:语言精髓笔记1--标识符与基本类型

    标识符: 命名: 语法以及类型----语法关键字                                           //逻辑 值(的存储位置)----变量和常量           ...

  9. js:语言精髓笔记10--闭包

    闭包:  //JS函数式风格中,在内部保存数据和对外无副作用这两个特性主要就是通过闭包实现的: 函数与闭包: 一个函数是一段静态代码,它是一个代码书写时已经编译期,静态概念:闭包是函数在代码运行过程中 ...

随机推荐

  1. javascript常用排序算法总结

    算法是程序的灵魂.虽然在前端的开发环境中排序算法不是很经常用到,但常见的排序算法还是应该要掌握的.我在这里从网上整理了一下常见排序算法的javascript实现,方便以后查阅. 归并排序: 1 fun ...

  2. hdu.5203.Rikka with wood sticks(数学推导:一条长度为L的线段经分割后可以构成几种三角形)

    Rikka with wood sticks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/O ...

  3. HNU 12833 Omar’s Bug(分情况讨论)

    题目链接:http://acm.hnu.cn/online/?action=problem&type=show&id=12833&courseid=268 解题报告:有个11个 ...

  4. [Effective JavaScript 笔记]第3章:使用函数--个人总结

    前言 这一章把平时会用到,但不会深究的知识点,分开细化地讲解了.里面很多内容在高3等基础内容里,也有很多讲到.但由于本身书籍的篇幅较大,很容易忽视对应的小知识点.这章里的许多小提示都很有帮助,特别是在 ...

  5. Linux瑞士军刀:密码管理Keeweb

    导读 如今,我们依赖于越来越多的线上服务.我们每注册一个线上服务,就要设置一个密码:如此,我们就不得不记住数以百计的密码.这样对于每个人来说,都很容易忘记密码.我将在本文中介绍 Keeweb,它是一款 ...

  6. Coursera台大机器学习课程笔记9 -- Logistic Regression

    如果只想得到某种概率,而不是简单的分类,那么该如何做呢?在误差衡量问题上,如何选取误差函数这段很有意思. 接下来是如何最小化Ein,由于Ein是可凸优化的,所以采用的是梯度下降法:只要达到谷底,就找到 ...

  7. ZeroMQ(java)中的数据流SessionBase与SocketBase

    前面的文章中已经比较的清楚了ZeroMQ(java)中如何在底层处理IO, 通过StreamEngine对象来维护SelectableChannel对象以及IO的事件回调,然后通过Poller对象来维 ...

  8. LSB 简介

    前 Linux 的发行版非常繁多,为了促进 Linux 不同发行版间的兼容性,LSB(Linux Standards Base)开发了一系列标准,使各种软件可以很好地在兼容 LSB 标准的系统上运行, ...

  9. Linux命令之exit - 退出当前shell【返回值状态】

    原文链接:http://codingstandards.iteye.com/blog/836625   (转载请注明出处) 用途说明 exit命令用于退出当前shell,在shell脚本中可以终止当前 ...

  10. 如何选择Html.RenderPartial和Html.RenderAction

    Html.RenderPartial与Html.RenderAction这两个方法都是用来在界面上嵌入用户控件的. Html.RenderPartial是直接将用户控件嵌入到界面上: <%Htm ...