sizzle编译函数】的更多相关文章

一个人去完成一件事情,如果派多个人去做的话,只要配合默契,效率比一个人做肯定要高,效率提高,所需的时间就减少了.如果只能一个人完成,那么必须设法提高自己的劳动效率,这个提高可以是量的改变也可以是质的改变.我把这个量的改变称为空间上的改变,也就是说空间和时间是可以相互转换的. 按照解析原理与过滤器的原理一次用循环递归去匹配查找,这样的效率是很慢的,那么sizzle从给1.8开始就引入了编译的概念,就是空间换时间的算法通过缓存大量的闭包匹配器从而提高重复的效率 闭包是js的特性,我们经常会用来作为私…
声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢! 从Sizzle1.8开始,这是Sizzle的分界线了,引入了编译函数机制 网上基本没有资料细说这个东东的,sizzle引入这个实现主要的作用是分词的筛选,提高逐个匹配的效率 我们不直接看代码的实现,通过简单的实现描述下原理: 以下是个人的理解,如果有错误欢迎指出! Javascript有预编译与我们说的编译函数是不同的概念 什么是JavaScript的“预编译”? function Aaron() { alert("he…
在用前两篇讲述完正则表达式.初始化.特性检测之后,终于到了我们的正餐——Sizzle工厂函数! Sizzle工厂函数有四个参数, selector:选择符 context:查找上下文 results:返回的结果数组 seed:待选元素,刚开始是undefined,但有的情况下Sizzle会递归调用,故那个时候会将待选元素层层传递 当我们要使用Sizzle时,使用频率最高的通常是直接指定单个id.class.tag来获取(通常还指定查找上下文来加速这一过程),而这种情况下Sizzle做了优化,当判…
动态编译函数compile调用语法如下: compile(source, filename, mode, flags=0, dont_inherit=False, optimize=-1) 其中的filename参数用于在执行代码报错的运行时错误消息中提示代码来源相关的信息,是一个类似备注信息,没有任何其他意义,不影响compile的执行,可以是任何值. 该参数对应的信息,当source是执行代码从文件中读取的代码字符串时,建议存放文件名,如果不是从文件里读取源码来编译,那么这里可以放一些用来标…
在上一章中,我们说到在之前的查找阶段我们已经获得了待选集seed,那么这一章我们就来讲如何将seed待选集过滤,以获得我们最终要用的元素. 其实思路本质上还是不停地根据token过滤,但compile这个函数将这些matcher(filter生成的闭包过滤函数)给编译成一个函数(这个效率和我们直接使用过滤函数差不多,关键是在后面),再保存这一个函数,以后遇到同样的selector就可以不用再编译,直接调用就可以了. 接下来我们看看compile的代码 compile = Sizzle.compi…
转自:http://blog.csdn.net/u012365926/article/details/51446295 基本概念 什么是库 在windows平台和linux平台下都大量存在着库. 本质上来说库是一种可执行代码的二进制形式,可以被操作系统载入内存执行. 由于windows和linux的平台不同(主要是编译器.汇编器和连接器的不同),因此二者库的二进制是不兼容的. 本文仅限于介绍linux下的库. 库的种类 linux下的库有两种:静态库和共享库(动态库). 二者的不同点在于代码被载…
funcname = "func" func = "def %s():\n" % funcname funccontent = 'print "hello,world"' func += funccontent evalcode = compile(func, '', 'eval') exec (evalcode) eval("%s" % funcname) 执行后编译错误: eval_code = compile(func,…
这一节要分析的东东比较复杂,篇幅会比较大,也不知道我描述后能不能让人看明白.这部分的源码我第一次看的时候也比较吃力,现在重头看一遍,再分析一遍,看能否查缺补漏. 看这一部分的源码需要有一个完整的概念后去看才比较容易看懂,所以我们先把整个编译的原理阐述以后再进行解析. 还是以上次的那个CSS选择器为例:#chua > a + .group labe[for="age"].按照我们正常解析CSS的思路从右往左解析(这是效率较高的处理方法),解析之前词法分析完毕,词法分析结果保存在to…
1.JS总体上分为:原始值和引用值 原始值分为:Number.Boolean.String.undefined.null;原始值不可改变的值,存储在栈[stack]的,先进后出! 引用值:array.Object.function.date.RegExp:原始值是可改变的,引用值大体是存储在堆[heap]中: 说明:一个变量经过声明,但是没有赋值,默认情况下就是undefined!例如: <body> <script type="text/javascript">…
本文只探讨纯粹的函数,并不包含方法.对于方法,会放到类.对象中一起研究. 想讲清楚在zend vm中,函数如何被正确的编译成op指令.如何发生参数传递.如何模拟调用栈.如何切换作用域等等,的确是一个很大范畴的话题.但为了弄明白php的原理,必须要攻克它. 对函数的研究,大致可以分成两块.第一块是函数体的编译,主要涉及到如何将函数转化成zend_op指令.第二块是研究函数的调用,涉及到函数调用语句的编译,以及函数如何被执行等topic.这里先来看看函数如何被编译,我们下一篇再讲函数的调用. 函数的…