c编译器扩展原理
1、char *p="asdf"; 则sizeof(p)=2; 是返回指针p占用字节数;即使你是先定义再赋值,char *p; p="asdfasdf"; sizeof(p)都是等于2;任何指针在turbo c中都是2个字节,不是说“字符串中有'0\'占一个字节,字符类型指针占一个字节”。。楼上有的说sizeof(p)是求变量p或字符串长度,是错的,是求占用字节数,不是长度,长度是用函数strlen(p); sizeof不是函数,是一种运算符。。例子:char p[]="abc";则sizeof(p)=4;strlen(p)=3; 比较于char p[10]="abc"; sizeof(p)=10; strlen(p)=3。。。 但如果定义成:char p[]="asdf"; 则sizeof(p);就等于5了,数组名p虽然可以看做指针,但不完全跟指针一样,这就是例子了。。 2、编译器可以看作一个虚拟机器,可以有自己虚拟的内存,栈等。。编译系统就可以看作是物理电脑操作系统上虚拟机的运行系统。。所以不一定是物理地址,但跟物理地址有映射关系,至于为什么,怎么映射,我也不知道。。。 3、编译器是16位。。跟“loat 为4个字节 double 32个字符”??。。跟float 4字节32位没关系,那是编译器设定的,就是常说电脑是16位或32位操作系统一样,编译器16位就看作虚拟机器是16位运行系统。。 4、 我也不知道为什么, (*p)(int,int);是int (*p)(int,int);吧。。。
❷ c语言编译器是用什么于语言写的
第一个C语言编译器应该是用汇编写的,但是第一个成熟的C语言编译器应该是由汇编和C语言共同写的。
编译原理讲到了“自举编译器”。大意就是先用底层语言(应该是汇编)写一个能运行,但效率极低的C语言编译器(底层语言不好优化),有了C语言的编译器以后,就可以用C语言好好写一个编译器了,用之前那个运行没问题,但效率低得编译器编译一下,就得到了可以使用的编译器了。
❸ 如何编译并运行C语言程序
1、创建一个文件名为main.c,然后用任意一个款你熟悉的文本编辑软件,比如说记事本,在里面输入下面的代码,记住,要用文本文件编辑软件,不能用word的。
(3)c编译器扩展原理扩展阅读:
c语言小游戏实现原理
1、二维数组实现棋盘
二维数组,用两个for 循环,随便输出一个固定符号做棋盘,如 *
2、判定玩家
设计一个计步变量step, 每走一步 step++, 则玩家=step%2+1;
3、判定输赢(重点)
设计方向数组 dircX[4] ,dircY[4],因为如果要判断是否练成五子,只有1竖着2横着3斜下4斜上
竖着的话就是 x-1,y不变
横着的话就是x不变,y+1; 斜下: x+1,y+1; 斜上 x-1;y+1
这样你就可以赋值dircX={-1,0,1,-1} dercY={0,1,1,1}
每当玩家落下一子,就全局判断每个子的四个方向有没有第二子,如果有,循环判断有没有第三子(利用 x+=dircX[1]),直到五子完成,结束。
❹ C语言工作原理
作为一种编程语言,本身是谈不上工作原理的,实际上C语言所有的语法,正是C语言编译器的工作原理或者工作机制的具体实现。要细致的讨论起来是不可能,但是作为C语言程序员,必须了解这个大致的流程。一个程序,从C语言源码,到系统可执行的文件,一般经历四个过程。
1、预处理阶断,这个阶断是文本处理阶断,有预处理器来完成,会将源码中的带"#"开头的预处理命令进行相应的处理,在linux上C语言的预处理器程序是cp命令。
2、编译阶断,这个阶断是有C语言编译阶断,在Linux上C语言的编译器是cc命令,它将C语言源码转换成汇编指令。
3、汇编阶断,这个阶断是汇编编译阶断,在Linux上C语言的汇编器是as命令,这个阶断会将汇编指令编译成二进制机器码。
4、链接阶断,这个阶断是会将汇编阶断生成的机器码目标文件,装载成一个系统可执行的文件,在Linux平台以ELF格式进行组装,在Windows平台上以PE格式进行组装。在Linux平台上的链接器命令为ld,在windows平台上的链接器命令为linker。
❺ C语言中编译程序和连接程序的作用和原理是什么关键是原理,越详细越好,谢了~
详细了你也不一定能理解,你对底层的了解程度如何?
简单的来说编译就是生成语言无关的obj文件,连接就是将所有的obj文件连接起来,查找里面的符号按照COFF文件的标准生成dll或EXE。
❻ C语言编译器是用来做什么的
编译器,是将便于人编写,阅读,维护的高阶计算机语言翻译为计算机能解读、运行的低阶机器语言的程序。编译器将原始程序(Source program)作为输入,翻译产生使用目标语言(Target language)的等价程序。源代码一般为高阶语言 (High-level language), 如 Pascal、C++、Java 等,而目标语言则是汇编语言或目标机器的目标代码(Object code),有时也称作机器代码(Machine code)。
一个现代编译器的主要工作流程如下:
源代码 (source code) → 预处理器 (preprocessor) → 编译器 (compiler) → 汇编程序 (assembler) → 目标代码 (object code) → 连接器 (Linker) → 可执行程序 (executables)
❼ linux下c语言编译器的工作原理是怎么样的/
c语言编译器的工作原理都差不多的。一般来说分为四个阶断;
1、预处理阶断,主要是文本替换操作。有预处理器完成。
2、编译阶断,将C源码生成汇编代码,这个是有C语言编译器来完成的,默认linux下是cc。
3、汇编阶断,将汇编代码,生成相应的可执行体,即二进制文件。
这个过程都可以自己通过给gcc加入参数来详细的获取这些过程的,具体可以参考:http://jingyan..com/article/03b2f78c1d6ede5ea237aed7.html
❽ c语言编译器是用什么于语言写的
第一个C语言编译器应该是用汇编写的,但是第一个成熟的C语言编译器应该是由汇编和C语言共同写的。
编译原理讲到了“自举编译器”。大意就是先用底层语言(应该是汇编)写一个能运行,但效率极低的C语言编译器(底层语言不好优化),有了C语言的编译器以后,就可以用C语言好好写一个编译器了,用之前那个运行没问题,但效率低得编译器编译一下,就得到了可以使用的编译器了。