资源整理:

风云老师博客:

http://blog.codingnow.com/eo/luaoeeeaeau/

知乎:

https://www.zhihu.com/question/20736660

http://del.icio.us/musicode/lua

---------------------------------------

C语言学到什么程度可以看Lua的源码?修改

除了C语言之外还需要什么能力?
如果说是为了培养编程能力,是否有更好的方式?
作者:airtrack
链接:https://www.zhihu.com/question/20736660/answer/22313839
来源:知乎
著作权归作者所有,转载请联系作者获得授权。

首先你需要学会lua(不仅仅是C语言水平的问题),这里的学会我指的是能用lua写个几千上万行业务代码,对lua有了一定的理解,再根据你自己理解找找对lua哪方面感兴趣,专门针对那方面去看lua的代码,比如函数调用是怎么实现的(以及与C语言怎么交互的)、lua的debug库是怎么提供hook指令执行的等等。你看云风那么多lua分析的文章都是这段时间关注GC就看GC的实现,那段时间关注string的实现就看string的相关代码。找到你关注的感兴趣的部分去看,比你在14588行代码(lua 5.2.3的代码,排除注释和空行)乱无头绪的看要好多了。

如果你想通过看lua代码学习编译原理的知识,那自然就看词法分析、语法分析、代码生成及VM代码,这方面我曾写过三篇博客(lua源码剖析(一)lua源码剖析(二)lua源码剖析(三))。不过我不推荐通过lua源码来学习编译原理,因为很难在lua这种工业级的解释器里理清交杂在一起的语法分析、语义分析以及代码生成。lua本身是一个一遍式的编译器,我觉得对于初学者来说这是不好理解的,在这个一遍式的编译器里还交杂着GC和运行时报错的准备工作,另外一方面lua的代码变量太短,经常是一个字母,不好读(至少我是这么认为的),各个模块之间耦合也很大程度的影响理解。我觉得学习编译原理最好的方式是,先通看一遍编译原理,然后硬着头皮写一个渣编译器(解释器),这时候你再来看lua这块的代码会好很多。我在看lua代码之前,就是自己实现了一个lua的子集,我目前正在写第二版的实现(luna第二版:airtrack/luna · GitHub 只是子集,没有metatable userdata coroutine等东西),luna的第一版我实现了一个渣一般的栈虚拟机,在看了lua的代码之后,我想实现一个寄存器虚拟机,于是写了第二版。在写第二版的时候有时候遇到某个问题,觉得我自己的想法实现成本太高时(运行时的时空代价),我就会看看lua是怎么实现的,比如运行时报错(f()函数调用,f本身不是函数的报错),而这时候我已经有过自己的思考,再去看lua的这块实现,看代码3-5分钟就看到了重点,醍醐灌顶,然后迅速的实现出来。其实到目前为止我都没有完整的看过lua的代码。

另外lua的是一个工业级的解释器,它的很多实现方式是有效率考虑的(比如一遍式的编译),而且很多实现方面都是在它这个语言之下是很优的(也许是最优的),如果换做另外一门语言,是不能完全套用它的实现方式,当然原理是通的,所以我觉得关键还是理解实现后面的原理,不单单是看怎么实现的。

 
 
前面已经说的很多了.

我来补充一点吧.Lua里面用到编译知识确实不多,也不太难,比如语法解析用的是最简单的递归下降,而不是LALR之类比较难的.

但并不是说Lua里面用到的相应知识就一定简单.比如Lua是一遍分析的,我们学编译的时候一般是两遍,一遍先生成分析树,然后再遍历一遍生成opcode,而Lua跳过了生成分析树这一步直接生成Opcode,另外语法翻译这部分我现在看的还是比较头大.

简而言之,我认为Lua中用到的编译的知识基本上到龙书的第五章语法制导翻译这部分就足矣了.但是知识点少,并不意味着就是简单,因为Lua追求的时简洁和高效.

作者:codedump
链接:https://www.zhihu.com/question/20736660/answer/22218382
来源:知乎
著作权归作者所有,转载请联系作者获得授权。

 
 
LUA代码重点的部分除了数据结构,算法,词法语法,GC,VM等部分,还能够通过堆栈与C代码交互,如果你所谓的看LUA源码是要懂得这些的话,需要深入了解不只C,还有汇编和操作系统。如果单就能够了解LUA语言或了解解释器代码的话,能够对C的指针、寄存器、函数调用较为了解的话,就可以较为顺利的阅读了。
可以看看云风老大的文章,对LUA代码有一个大致的概念了解。

作者:张涛
链接:https://www.zhihu.com/question/20736660/answer/16008805
来源:知乎
著作权归作者所有,转载请联系作者获得授权。

 
这个问题是所谓的如何阅读开源代码的问题的一个典型例子。
首先你应该了解你想要阅读的源码是什么,如果你对你要阅读的源码缺乏基础的了解,那你就应该先去了解一下。 然后你就要对他进行归类,这样你才能做到有目的性的学习。然后就是针对归类进行专业的学习了。
其实对于很多开源代码来说,你会那种语言到什么程度,根本无足轻重。
拿你说的lua来说,他应该属于解释器/编译器类的代码,他的核心内容是语法分析,语义分析等等等等等编译或解释过程。从计算机科学的学科上来讲,他应该属于编译原理的范畴,编译原理的先导学科有很多,比如形式语言与自动机,比如句法结构等等。如果这些东西你掌握到家了 参照其代码中的注释,你可以很轻松的对其进行划分,然后你就可以轻松的自顶而下,分而治之了,到这种时候,其实你会的到底是C还是Pascal已经不重要了。因为你都可以轻松的理解代码中的真正精髓的东西

作者:刘虎
链接:https://www.zhihu.com/question/20736660/answer/21849915
来源:知乎
著作权归作者所有,转载请联系作者获得授权。

Lua学习系列(二)的更多相关文章

  1. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

  2. Maven学习系列二(1-5)

    Maven学习系列二(1-5) 本文转自 QuantSeven 博客,讲解精炼易懂,适合入门,链接及截图如下 http://www.cnblogs.com/quanyongan/category/47 ...

  3. scrapy爬虫学习系列二:scrapy简单爬虫样例学习

    系列文章列表: scrapy爬虫学习系列一:scrapy爬虫环境的准备:      http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_python_00 ...

  4. DocX开源WORD操作组件的学习系列二

    DocX学习系列 DocX开源WORD操作组件的学习系列一 : http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_sharp_001_docx1.htm ...

  5. [转]ASP.NET MVC学习系列(二)-WebAPI请求 传参

    [转]ASP.NET MVC学习系列(二)-WebAPI请求 传参 本文转自:http://www.cnblogs.com/babycool/p/3922738.html ASP.NET MVC学习系 ...

  6. RabbitMQ学习系列二-C#代码发送消息

    RabbitMQ学习系列二:.net 环境下 C#代码使用 RabbitMQ 消息队列 http://www.80iter.com/blog/1437455520862503 上一篇已经讲了Rabbi ...

  7. .net reactor 学习系列(二)---.net reactor界面各功能说明

    原文:.net reactor 学习系列(二)---.net reactor界面各功能说明         安装了.net reactor之后,可以在安装目录下找到帮助文档REACTOR_HELP.c ...

  8. 图机器学习(GML)&图神经网络(GNN)原理和代码实现(前置学习系列二)

    项目链接:https://aistudio.baidu.com/aistudio/projectdetail/4990947?contributionType=1 欢迎fork欢迎三连!文章篇幅有限, ...

  9. ASP.NET MVC学习系列(二)-WebAPI请求

    继续接着上文 ASP.NET MVC学习系列(一)-WebAPI初探 来看看对于一般前台页面发起的get和post请求,我们在Web API中要如何来处理. 这里我使用Jquery 来发起异步请求实现 ...

  10. ASP.NET MVC学习系列(二)-WebAPI请求(转)

    转自:http://www.cnblogs.com/babycool/p/3922738.html 继续接着上文 ASP.NET MVC学习系列(一)-WebAPI初探 来看看对于一般前台页面发起的g ...

随机推荐

  1. java动态代理(1)

    来源:http://www.cnblogs.com/jqyp/archive/2010/08/20/1805041.html# java动态代理(JDK和cglib) JAVA的动态代理 代理模式 代 ...

  2. IOS 中常用站位符

      CGPoint.CGRect等可以转化为字符串打印出来 如:   NSLog(@"-------------%@",NSStringFromCGPoint(point));   ...

  3. Delphi XE2 生成的.exe 在未安装有Delphi的电脑上运行提示 “丢失 rtl160.bpl”

    解决方案: XE2中加入了多平台的概念,默认的Release模式,也是带包编译,带运行时库的,所以,需要手工设置一下工程选项: 打开工程以后,Project-->Options-->左侧树 ...

  4. ref与out之间的区别整理 摘自与望楼http://blog.csdn.net/xiaoning8201/article/details/6893154

    ref和out都是C#中的关键字,所实现的功能也差不多,都是指定一个参数按照引用传递. 对于编译后的程序而言,它们之间没有任何区别,也就是说它们只有语法区别. 总结起来,他们有如下语法区别: .ref ...

  5. 【滚动数组】 dp poj 1036

    题意:一群匪徒要进入一个酒店.酒店的门有k+1个状态,每个匪徒的参数是:进入时间,符合的状态,携带的钱. 酒店的门刚开始状态0,问最多这个酒店能得到的钱数. 思路: dp数组为DP[T][K]. 转移 ...

  6. 【字母全排列】 poj 1256

    深搜   注意与STL模版的去重函数唯一的区别就是有去重. #include <iostream> #include <cstdio> #include <string. ...

  7. 由浅到深理解java反射

    1.基础概念 class类: 1.1java是面向对象的,但是在java中存在两种东西不是面向对象的 一种是普通的数据类型,这也是封装数据类存在的原因. 二种是静态静态成员. 1.2所以我们首先要理解 ...

  8. LA2965 n个数中选出最多个数异或和为0

    intput n 1<=n<=24 n串只有大写字母的字符串 output 选出最多个字符串且每个大写字母出现的次数为偶数 第一行输出个数x 第二行输出x个字符串的下标 做法:将每个字符串 ...

  9. 代码创建xml文档并写入指定节点

    //首先创建 XmlDocument xml文档 XmlDocument xml = new XmlDocument(); //创建根节点 config XmlElement config = xml ...

  10. HDU 5768 Lucky7 (容斥原理 + 中国剩余定理 + 状态压缩 + 带膜乘法)

    题意:……应该不用我说了,看起来就很容斥原理,很中国剩余定理…… 方法:因为题目中的n最大是15,使用状态压缩可以将所有的组合都举出来,然后再拆开成数组,进行中国剩余定理的运算,中国剩余定理能够求出同 ...