发布时间:2023-11-30 21:09来源:www.sf1369.com作者:宇宇
Java编译原理:
Java 虚拟机(JVM)是可运行Java 代码的假想计算机。只要根据JVM规格描述将解释器移植到特定的计算机上,就能保证经过编译的任何Java代码能够在该系统上运行。
一.Java源文件的编译、下载 、解释和执行
Java应用程序的开发周期包括编译、下载 、解释和执行几个部分。Java编译程序将Java源程序翻译为JVM可执行代码?字节码。这一编译过程同C/C++ 的编译有些不同。当C编译器编译生成一个对象的代码时,该代码是为在某一特定硬件平台运行而产生的。因此,在编译过程中,编译程序通过查表将所有对符号的引用转换为特定的内存偏移量,以保证程序运行。Java编译器却不将对变量和方法的引用编译为数值引用,也不确定程序执行过程中的内存布局,而是将这些符号引用信息保留在字节码中,由解释器在运行过程中创立内存布局,然后再通过查表来确定一个方法所在的地址。这样就有效的保证了Java的可移植性和安全 性。
运行JVM字节码的工作是由解释器来完成的。解释执行过程分三部进行:代码的装入、代码的校验和代码的执行。装入代码的工作由类装载器(class loader)完成。类装载器负责装入运行一个程序需要的所有代码,这也包括程序代码中的类所继承的类和被其调用的类。当类装载器装入一个类时,该类被放在自己的名字空间中。除了通过符号引用自己名字空间以外的类,类之间没有其他办法可以影响其他类。在本台计算机上的所有类都在同一地址空间内,而所有从外部引进的类,都有一个自己独立的名字空间。这使得本地类通过共享相同的名字空间获得较高的运行效率,同时又保证它们与从外部引进的类不会相互影响。当装入了运行程序需要的所有类后,解释器便可确定整个可执行程序的内存布局。解释器为符号引用同特定的地址空间建立对应关系及查询表。通过在这一阶段确定代码的内存布局,Java很好地解决了由超类改变而使子类崩溃的问题,同时也防止了代码对地址的非法访问。
随后,被装入的代码由字节码校验器进行检查。校验器可发现操作数栈溢出,非法数据类型转化等多种错误。通过校验后,代码便开始执行了。
Java字节码的执行有两种方式:
1.即时编译方式:解释器先将字节码编译成机器码,然后再执行该机器码。
2.解释执行方式:解释器通过每次解释并执行一小段代码来完成Java字节码程 序的所有操作。
通常采用的是第二种方法。由于JVM规格描述具有足够的灵活性,这使得将字节码翻译为机器代码的工作
具有较高的效率。对于那些对运行速度要求较高的应用程序,解释器可将Java字节码即时编译为机器码,从而很好地保证了Java代码的可移植性和高性能。
以代码(高级语言)输入,对应的语句翻译成为汇编语言(编译),无误后再译为机器语言(纯0,1码)
程序运行其实只有1.指针(磁头)移位(上位,下位)2.写入1或0(或反码)
过程挺复杂的,其实就是翻译过程...
第一个fun函数读入输入的字符串abcdefghij的第一个字符a,此时n=10大于1 递归调用第二个fun函数
第二个fun函数读入第二个字符b,此时n=9大于1 递归调用第三个fun函数
。。以此类推
第九个fun函数读入第九个字符i,此时n=2大于1 递归调用第十个fun函数
第十个fun函数读入第十个字符j,此时n=1,直接输出第十个字符j,返回调用它的第九个fun函数
第九个fun函数输出第九个字符i,返回调用它的第八个fun函数
。。逐级返回上层
最后最开始的那个fun输出第一个字符a
这样输出就是倒叙了。。
不过此函数没有引用std名字空间 所以cin cout前面必须加std::否则应该不能编译
可以直接改为
#include<iostream>
using namespace std;
int main()
{
char a[11],*p;
cin>>a;
for(p=a+strlen(a)-1;p>=a;p--)cout<<*p;
return 0;
}
先面向过程,程序都是由一系列的过程进行的,你所编的程序就是把你要做的事情用代码告诉计算机一步一步的,然后计算机看懂你的意思了,它就干你想让它做的事了。就好像你写了一道菜的制作工序,拿给一个认识字的厨师,厨师看你的要求做菜,用多少材料,先放油后放盐等等的工序就是你要告诉厨师的。现在,你面对的是电脑不是人,你要把人的语言转换成计算机的语言,一步步告诉它按你的要求做事。这么说你该懂了吧?