java代码自动生成c Java代码自动生成类图

Java语言如何直接转换为c语言?这个问题我只能大概的说一下java代码自动生成c,具体区别只有在你以后用的时候去比较java代码自动生成c了 。
Java程序中的每个变量要么是基本数据类型(boolean, char, byte, short, int, long, float, double),要么是对对象的引用;
C有许多种基本类型,额外还有struct, union, enum, 数组和指针,C指针可以指向对象,也可以不指向对象;
Java没有枚举、联合类型 , 因为Java认为没有必要 。将可有可无的语言元素去掉是Java对C/C做出的一大改变,因此,普遍认为Java较C更轻便,更精简;
Java采用Unicode字符集 , C通常用ASCII字符集 。但ASCII是Unicode的子集,对于习惯于ASCII的程序员感觉不到区别;
Java中的boolean类型不能转换成其java代码自动生成c他类型,反之亦然 。C最近引进了bool类型,代表布尔类型,整型也作为逻辑判断;
模板是一种“泛型编程思想”,它有别于“面向对象编程思想” 。C在很大程度上已经支持了这种新型编程方法 , 特别是STL的出现;
Java目前仍未支持泛型编程 , 不过据说Sun公司有在Java中引入模板的计划;
C支持“运算符的重载”,这是它的一个很重要的多态特征,是数据抽象和泛型编程的利器 。它允许直接对对象进行四则运算,正像基本数据类型那样;
Java不支持这种多态机制,也是为降低复杂性;
两种语言都支持方法重载(overloading)
在C中,为了允许运行时动态决定哪个函数被调用,一个函数必须用virtual修饰 。virtual关键字被自动继承,用以支持多态;
凡是没有用virtual修饰的成员函数(包括static)都是静态绑定的,即在编译时决定调用哪个版本
而在Java中,除了static、final、private是静态绑定以外,所有方法一律按动态绑定处理
C中有“拷贝构造函数”的概念,在三种情况下,自动调用它
用一个对象初始化另一对象
对象作实参进行函数调用
对象作函数的返回值
通常 , 当一个对象需要做“深拷贝”(钱能:《C程序设计教程》)时,我们需要为它事先定义“拷贝构造函数”、“赋值运算符的重载函数”和“析构函数”;否则编译器将以“按位copy”的形式自动生成相应的缺省函数 。倘若类中含有指针成员或引用成员,那么这三个默认的函数就隐含了错误
Java则没有这种语法结构和语义逻辑
C支持inline函数,可以避免函数的堆栈调用 , 提高运行效率
Java无这种语义
C中,构造函数的初始化列表是这样使用的:首先按继承顺序调用基类的构造函数构造基类对象 , 然后按声明顺序调用成员对象的构造函数构造成员对象,最后对列表中出现的成员变量做初始化
Java不采用初始化列表这种构造机制
它们的构造顺序基本一致:
静态变量初始化
静态初始化块(Java)
调用基类的构造函数构造基类对象
实例变量的初始化
构造函数的其余部分
Java使用abstract关键字修饰抽象方法或抽象类
C的对等语法是“纯虚函数”和“抽象类”
两者都使用抽象类作为继承层次中的基类,提供一般概念,由子类实现其抽象方法,且抽象类都不能被直接实例化为对象
Java中有final关键字,修饰类、方法或变量
final类不能被继承
final方法不能被子类覆盖
final变量就是常量
C中没有这个关键字,常量可以使用const或#define定义
const还可以修饰成员函数 , 即“常成员函数”,当一个const成员函数修改成员数据,或调用非const成员函数时,编译器会报错
我们应将不修改成员数据的函数声明为const
Java和C中的static关键字语法和语义基本相同
static成员变量又叫类变量,被类的所有对象共享
A::x (C):必须在类体外初始化
A.x (Java):必须在类体内初始化
static成员方法又叫类方法 , 访问static变量
A::f( ) (C)
A.f( ) (Java)
两者都有内部类和局部类的语法和语义
Java中没有友元函数和友元类的概念,严格支持封装,不允许外部方法访问类的私有成员
而C支持friend关键字,允许外部方法访问类的私有成员,因此不是一种纯面向对象的编程语言
Java中类或interface可以用public修饰 , 也可以不修饰;而C类不能修饰
三种访问权限的语义相同 , 语法略有差别
C中还有继承权限修饰符 , Java则没有
class A: protected B, public C (C)
class A extends B (Java)
Java有super关键字,指代父类对象,通常被用于调用父类的构造方法或一般方法
C则没有super关键字
两者都有this,指代当前对象
Java有package的概念,可以将类组织起来,便于打包和部署,也有利于类的安全 。C没有这个概念 , 一个类可以被任意类访问
Java applet可以被嵌入HTML文档中,然后由Web浏览器下载和执行
Java API有对网络通讯的特别支持
C则无内置网络功能
C程序员必须显式地实现动态内存管理,在析构函数中用delete运算符或free( )函数释放对象和其java代码自动生成c他动态分配的数据空间 , 否则会造成“内存泄露”
而在Java中,垃圾收集是自动的 。当对象的最后一个引用变量被释放掉,这个对象就成为垃圾收集器的候选对象了
因此Java不支持析构函数
finalize( )方法主要被用来释放先前打开的非内存资源,如文件句柄
Java源代码被编译成字节码(.class文件),字节码是一种只有JVM才能识别的二进制低级代码,它与具体的处理器无关,要由安装在OS之上的JVM解释执行,转换成相应平台的机器码,因此Java是体系结构中立和跨平台的
而C直接被编译成底层平台的二进制机器码,由CPU执行,是平台相关的
因此,当解释执行时 , Java程序速度更慢
Java语言支持多线程 , 允许并发线程的同步与互斥操作
C则没有这种内在机制
Javadoc.exe可以将Java程序的内容和结构转换成HTML格式的文档
C是面向过程的 , C和JAVA是面向对象的
主要是差别对象的概念
JAVA和C人说的比较多的主要的是有没有指针的差别
java简单易学但效率不高!
c相反有点麻烦效率高!
还有就是Java的可移植性好!能实现跨平台,即一次编写到处适用!
C 是面向过程的程序设计语言 。C++是面向对象的程序设计语言,不过C++语言保持了对C语言的兼容,也就说是在C++程序可以不用修改的插入C语言代码 。JAVA也是面向对象的程序设计语言 , 主要是实现平台无关性,它的出现主要为了实现对一种智能终端的编程(有人设想在不远的将来,你的冰箱有可能自己知道里面的东西已经不多 , 按着你的需要向应的供货商进行订购 。在你上班的时候也可以通过互联网开启你家里的微波炉 , 回到家就好吃的东西
还有JAVA主要应用于上层,用户使用JAVA不需要知道网络协议的细节,只需要知道如何调用相关接口就是了
C和C主要应用于网络底层,用C和C的程序员必须对协议有相关认识~
这个java代码怎么转换成C语言代码使用词法分析可以简单的进行转换,不过问题是接口,java使用的库类和函数,c并不一定拥有,而且java运行的方式不同(java可以说是解释器的脚本,而c最终变成指令集),并不是简单给出一个函数调用位置就可以解决的,目前的话可以实现个转化器(如果你学过编译原理),但前提是不使用接口,或许我们可以像编译器对string类型的支持那样实现所有java的库操作,但这显然是鸡肋,因为这种方法写的java程序转换后是很难移植的(显然我是说硬件厂商不会为你天真的想法提供接口),并且对c风格来说是一种极大的破坏,最后生成的代码既没有效率也没有可移植性和可读性
结论是你还不如自己实现一个,即使你要转化一个大游戏,这样也有效多了
写一段java代码 , 调用c程序,都有什么办法JAVA以其跨平台的特性深受人们喜爱,而又正由于它的跨平台的目的,使得它和本地机器的各种内部联系变得很少,约束了它的功能 。解决JAVA对本地操作的一种方法就是JNI 。
JAVA通过JNI调用本地方法,而本地方法是以库文件的形式存放的(在WINDOWS平台上是DLL文件形式,在UNIX机器上是SO文件形式) 。通过调用本地的库文件的内部方法,使JAVA可以实现和本地机器的紧密联系,调用系统级的各接口方法 。
简单介绍及应用如下:
一、JAVA中所需要做的工作
在JAVA程序中 , 首先需要在类中声明所调用的库名称,如下:
static {
System.loadLibrary(“goodluck”);
}
在这里,库的扩展名字可以不用写出来,究竟是DLL还是SO,由系统自己判断 。
还需要对将要调用的方法做本地声明,关键字为native 。并且只需要声明,而不需要具体实现 。如下:
public native static void set(int i);
public native static int get();
然后编译该JAVA程序文件 , 生成CLASS,再用JAVAH命令,JNI就会生成C/C的头文件 。
例如程序testdll.java , 内容为:
public class testdll
{
static
{
System.loadLibrary("goodluck");
}
public native static int get();
public native static void set(int i);
public static void main(String[] args)
{
testdll test = new testdll();
test.set(10);
System.out.println(test.get());
}
}
用javac testdll.java编译它 , 会生成testdll.class 。
再用javah testdll , 则会在当前目录下生成testdll.h文件,这个文件需要被C/C程序调用来生成所需的库文件 。
二、C/C中所需要做的工作
对于已生成的.h头文件,C/C所需要做的,就是把它的各个方法具体的实现 。然后编译连接成库文件即可 。再把库文件拷贝到JAVA程序的路径下面 , 就可以用JAVA调用C/C所实现的功能了 。
接上例子 。我们先看一下testdll.h文件的内容:
/* DO NOT EDIT THIS FILE - it is machine generated */
#include jni.h
/* Header for class testdll */
#ifndef _Included_testdll
#define _Included_testdll
#ifdef __cplusplus
extern "C" {
#endif
/*
* Class: testdll
* Method: get
* Signature: ()I
*/
JNIEXPORT jint JNICALL Java_testdll_get
(JNIEnv *, jclass);
/*
* Class: testdll
* Method: set
* Signature: (I)V
*/
JNIEXPORT void JNICALL Java_testdll_set
(JNIEnv *, jclass, jint);
#ifdef __cplusplus
}
#endif
#endif
在具体实现的时候,我们只关心两个函数原型
JNIEXPORT jint JNICALL Java_testdll_get (JNIEnv *, jclass);

JNIEXPORT void JNICALL Java_testdll_set (JNIEnv *, jclass, jint);
这里JNIEXPORT和JNICALL都是JNI的关键字 , 表示此函数是要被JNI调用的 。而jint是以JNI为中介使JAVA的int类型与本地的int沟通的一种类型 , 我们可以视而不见,就当做int使用 。函数的名称是JAVA_再加上java程序的package路径再加函数名组成的 。参数中,我们也只需要关心在JAVA程序中存在的参数,至于JNIEnv*和jclass我们一般没有必要去碰它 。
好,下面我们用testdll.cpp文件具体实现这两个函数:
#include "testdll.h"
int i = 0;
JNIEXPORT jint JNICALL Java_testdll_get (JNIEnv *, jclass)
{
return i;
}
JNIEXPORT void JNICALL Java_testdll_set (JNIEnv *, jclass, jint j)
{
i = j;
}
编译连接成库文件,本例是在WINDOWS下做的,生成的是DLL文件 。并且名称要与JAVA中需要调用的一致 , 这里就是goodluck.dll
把goodluck.dll拷贝到testdll.class的目录下 , java testdll运行它,就可以观察到结果了 。
java代码如何生成可运行的程序 例如c一样,编译后有exe java是不是一定要jdk??JDK是开发环境
运行java必须得有JRE环境
可以把java打成jar包然后将jar包可以打成exe文件 用JSmooth工具可以把jar打成exe
【java代码自动生成c Java代码自动生成类图】关于java代码自动生成c和Java代码自动生成类图的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。

    推荐阅读