百科问答小站 logo
百科问答小站 font logo



Tiny C Compiler是个怎样的编译器?有人更新吗? 第1页

  

user avatar   rednaxelafx 网友的相关建议: 
      

Tiny C Compiler(TCC)原本是Fabrice Bellard大神用C语言实现的一个C语言编译器。它自身体积非常,编译/链接速度非常,生成的代码质量一般,可以自举(自己可以编译自己)。就如另外那个答案所说,这些特点在官网上都写得很清楚。

官方网站:

TCC : Tiny C Compiler

,官方文档:

Tiny C Compiler Reference Documentation

顺带:Fabrice Bellard大神的另一个好玩的项目,

Javascript PC Emulator

,里面的Linux镜像里就带有TCC。于是TCC在浏览器里也可以玩。

虽然Fabrice大神已经不维护TCC好多年,但还是有不少有爱的人在持续更新它的。

Git repo在此:

Public Git Hosting - tinycc.git/summary

<- 可以看到就今天都还有人在更新呢。

题主对小型C语言编译器感兴趣的话,请跳这个传送门:

有哪些关于c4 - C in four function 编译器的文章? - RednaxelaFX 的回答

我在那个回答里简单比较了C4与TCC、LCC等小型编译器的异同,也提到了一些资料链接(包括某本国内出的书)。欢迎参考。

简单介绍TCC的话,它跟上面说的C4类似,都是“单趟编译器”(one-pass compiler)——它的预处理(tccpp.c)、词法分析(tccpp.c)、语法分析(tccgen.c)、类型检查(tccgen.c)、代码生成(<arch>-gen.c)、汇编(其实直接生成了机器码,不经过汇编)、链接,全部都是在一趟里完成的。

由于是单趟编译器,TCC的编译流程中没有使用任何“中间表示”(intermediate representation,IR)。

TCC的预处理器、词法分析器与语法分析器都是手写的而不是生成的。

其中,语法分析器是典型的递归下降式(recursive descent),在语句层面与表达式层面都是。

整个编译流程基本上都是由语法分析所带动的。这种做法也叫做语法制导翻译(syntax-directed translation)。这是单趟编译器的典型做法。

代码生成使用的是基于栈的代码生成思路。这跟C4(特别是能生成x86机器码的C4x86)也是相似的。TCC在代码生成的过程中还做了很少量的优化,例如常量折叠。

顺带放个新传送门:

tcc -O2会做什么? - 编程语言与高级语言虚拟机杂谈(仮) - 知乎专栏



  

相关话题

  Visual Studio 2019可以用来玩C语言吗? 
  能否把高版本的libstdc++静态连接到一个只暴露纯C接口的动态库中,给低版本c++程序调用? 
  请问如何区分c语言中float和double的用法? 
  大型项目中面向过程思想 vs 面向对象思想,哪种开发效率更高? 
  请问,此题使用switch语句编写是否会比if更高效?若想用switch又该如何编写呢? 
  如何智能地在每个数字中间加一个「,」? 
  有什么像a=a+b;b=a-b;a=a-b;这样的算法或者知识? 
  为什么经常听人说编译器比你聪明? 
  为什么 C 语言 sqrt 函数参数不支持 int? 
  C语言编译器哪个好用? 

前一个讨论
大家都见过哪些让你虎躯一震的代码?
下一个讨论
如何解决用手机拍摄显示器时出现纹路的问题?





© 2024-12-26 - tinynew.org. All Rights Reserved.
© 2024-12-26 - tinynew.org. 保留所有权利