C_and_CPP 板


LINE

编译器真的很难。 https://descent-incoming.blogspot.com/2017/01/blog-post.html 这篇描述我的学习方式, 让你参考看看。 也列出我有购买的编译器书籍, 看看你有没有兴趣的。 https://descent-incoming.blogspot.com/2018/01/44.html 这几篇描述我一步步走来的纪录。 从建立 AST 到输出组合语言。 最後我也写了一个简单的组译器, 输出的 elf object file 可以和 gnu ld, link, 最後我停留在这里。 这几篇文章最主要是展示我的学习方式, 也许你有不同的学习之路。 我是建议产生 AST, 有了 AST, 後续的动作会很好处理。 ※ 引述《wei115 (NEET)》之铭言: : 问题(Question): : : 我想试试看实作一个C编译器 : 之前没有学过编译器,看了几个星期的资料後,还是不太懂编译器 : 不过土法炼钢,还是炼出了一些东西 : 因为不知道写一个编译器的难度,所以简化一下目标,只做编译器的前端 : 使用C作为中间语言,希望可以去除语法糖,和格式尽量和组合语言相近,以便後端实做 : 使用递回下降方法,没有多少检查(int str = "aabbcc"; 是可以的) : 语法3成参考K&R,7成用猜的,程式码写的不够合理,常常加一个功能就要动到整个专案 : 之後收集更多资料後会全部打掉重练 : 目前有做出int、char的宣告if、while : 之後想做阵列&指标的功能,但不知道指标的宣告和使用该如何简化 : 想请各位大大提供一些方向 : 谢谢 : p.s : 以一个1+...+100的回圈程式为例 : 输入: : int main() : { : int a = 101; : int out = 0; : while(a = a - 1) : out = out + a; : } : 输出: : int r0;int r1;int r2;int r3;int r4;int r5;int r6;int r7;int r8;int r9;int : r10;int r11;int r12;int r13;int r14;int r15;int r16;int r17;int r18;int r19; : int main() : { : r0 = 101; : int a = r0; : r0 = 0; : int out = r0; : L0: : r0 = a; : r1 = a; : r2 = 1; : r3 = r1 - r2; : r0 = r3; : a = r3; : if(!r0) goto L1; : r4 = out; : r5 = out; : r6 = a; : r7 = r5 + r6; : r4 = r7; : out = r7; : goto L0; : L1: : } : 希望输入的程式码可以转成这种最简形式 : -- : 「我不创造美少女,我只是从纸中看见了天使,并用手使她们自由。」 : ——矢吹 : -- :



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 59.126.109.77
: ※ 文章网址: https://webptt.com/cn.aspx?n=bbs/C_and_CPP/M.1557157798.A.E9F.html : → Lipraxde: 你知道 SSA form 是什麽东西吗?你好像是想在产生中间 05/07 07:41 : → Lipraxde: 表示法的时後做暂存器分配?暂存器分配是後端该做的事 05/07 07:41 : 会有这样的现象是因为我在乱写....,原本是计算机的形式(输入一个算式,输出是三位址 : 码),处理的时候是以一行作为单位,处理完之後,暂存器编号归零,後来扩充功能後这样 : 的形式也保留了下来 : ※ 编辑: wei115 (27.246.39.28), 05/07/2019 09:41:02 : → Lipraxde: 那你有 AST 吗? 05/07 11:10 : → wei115: 没有,词汇分析後用递回下降,直接输出中间码 05/07 11:53 : → wei115: 中间基本上全部写成一陀..... 05/07 11:54 : → Lipraxde: 先建立 AST,之後再从 AST 产生中间码会比较容易写 05/07 12:10 : → wei115: 目前对ast不够了解,之後收集足够的资料後打算全部重写, 05/07 12:26 : → wei115: 但是现在对要产生怎样形式的中间码还没有什麽头绪 05/07 12:26 : → Lipraxde: 用你原本的方法就好了啊,不然 java bytecode、llvm IR 05/07 13:22 : → Lipraxde: 之类的,还是你是打算後端也自己写? 05/07 13:22 : 普通的运算式我可以这样写,但像是指标和阵列我就不知道怎麽分解了...... : → Killercat: 可惜不是C++ 不然板上一堆CPPGM的心得 XD 05/07 13:47 : C++感觉更难...... : ※ 编辑: wei115 (27.246.39.28), 05/07/2019 14:03:13 -- 纸上得来终觉浅,绝知此事要躬行。 --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 113.196.174.254
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/C_and_CPP/M.1557223480.A.ACB.html ※ 编辑: descent (113.196.174.254), 05/07/2019 18:13:31
1F:推 cutekid: 推(Y) 05/07 20:29
2F:推 kishow01: 推推 刚刚好也在学编译器 05/07 21:12
3F:推 wei115: d大我有看你的文章!但我程度还是不够,要消化需要一段时 05/08 03:04
4F:→ wei115: 间 05/08 03:04
5F:→ wei115: 之後我会试试看实作AST 05/08 03:05







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:Tech_Job站内搜寻

TOP