高手进(JAVA下能否调用VB编译的动态链接库)
如题:   以前发过这个帖子,都说理论上说都可以,有没有真正在JAVA下调VB编译的动态连接库成功的?      急      急      急         谢谢各位大虾帮忙
------解决方案--------------------你是说调用dll文件吗?以前试过,网上有很多资料,由于必须读取客户端本地硬件,所以放弃,后来采用ocx,不过原理一样///////   
 首先确保你的dll发布服务啦,然后实例化该服务器上的dll,在调用该dll文件的公用接口。。。
------解决方案--------------------去网上搜jni的相关资料
------解决方案--------------------jni
------解决方案--------------------给你拷贝一文章,看看对你有帮助吗?   
 刚才用javah MyNative生成的MyNative.h头文件内容如下:  
    /* DO NOT EDIT THIS FILE - it is machine generated */ 
    #include  <jni.h>  
   /* Header for class MyNative */ 
   #ifndef _Included_MyNative 
    #define _Included_MyNative 
    #ifdef __cplusplus 
   extern  "C " { 
   #endif     
 /* 
   * Class:     MyNative 
   * Method:    HelloWord 
   * Signature: ()V 
 */ 
   JNIEXPORT void JNICALL Java_MyNative_HelloWord (JNIEnv *, jclass); 
   /* 
   * Class:     MyNative 
   * Method:    cToJava 
   * Signature: ()Ljava/lang/String; 
   */ 
   JNIEXPORT jstring JNICALL Java_MyNative_cToJava (JNIEnv *, jclass); 
   #ifdef __cplusplus 
   } 
   #endif 
   #endif 
 接下来,就是如何实现它了。其实,用JNI作出的东西也是DLL,被JAVA所调用。 
   在具体实现的时候,我们只关心两个函数原型: 
   JNIEXPORT void JNICALL Java_MyNative_HelloWord(JNIEnv *, jclass); 
      JNIEXPORT jstring JNICALL Java_MyNative_cToJava(JNIEnv *, jclass); 
 在project里面选择win32 Dynamic-link Library,然后点击下一步,其余的取默认。如果不取默认的,将会有dllmain()函数。取空DLL工程的话,将无这个函数。 
 然后选择new-> File-> C++ Source File,生成一个空*.cpp文件。取名为MyNative。把JNIEXPORT void JNICALL Java_MyNative_HelloWord(JNIEnv *, jclass);和JNIEXPORT jstring JNICALL Java_MyNative_cToJava(JNIEnv *, jclass);拷贝到CPP文件中去。然后把头文件包含进来。 
   生成的MyNative.cpp内容如下: 
   #include  <stdio.h>  
   #include  "MyNative.h " 
    JNIEXPORT void JNICALL Java_MyNative_HelloWord (JNIEnv *env, jclass jobject) 
  { 
   printf( "hello word!\n ");         
  } 
   JNIEXPORT jstring JNICALL Java_MyNative_cToJavaJNIEnv *env, jclass obj) 
   { 
   jstring jstr; 
   char str[]= "Hello,word!\n "; 
   jstr=env-> NewStringUTF(str); 
   return jstr; 
   }  
   在编译前一定要注意下列情况。 
   注意:一定要把SDK中的include文件夹中(和它下面的win32文件夹下的头文件)的几个头文件拷贝到VC的include文件夹中。或者在VC的tools\options\directories中设置,把头文件给包含进来。 
 对程序的一点解释: 
   1)加了static和不加只是一个参数的区别吗。就是jclass的不同,不加static这里就是jobject。也就是JNIEXPORT void JNICALL Java_MyNative_HelloWord(JNIEnv *env, jobject obj)。 
   2)这里JNIEXPORT和JNICALL都是JNI的关键字,表示此函数是要被JNI调用的。而jstring是以JNI为中介使JAVA的String类型与本地的string沟通的一种类型,我们可以视而不见,就当做String使用(具体对应见表一)。函数的名称是JAVA_再加上java程序的package路径再加函数名组成的(参见有包的情况)。参数中,我们也只需要关心在JAVA程序中存在的参数,至于JNIEnv*和jclass我们一般没有必要去碰它。 
   3)NewStringUTF()是JNI函数,从一个包含UTF格式编码字符的char类型数组中创建一个新的jstring对象。 
   4) 以上程序片断jstr=env-> NewStringUTF(str);是C++中的写法,不必使用env指针。因为JNIEnv函数的C++版本包含有直接插入成员函数,他们负责查找函数指针。而对于C的写法,应改为:jstr=(*env)-> NewStringUTF(env,str);因为所有JNI函数的调用都使用env指针,它是任意一个本地方法的第一个参数。env指针是指向一个函数指针表的指针。因此在每个JNI函数访问前加前缀(*env)-> ,以确保间接引用函数指针。 
   在C和Java编程语言之间传送值时,需要理解这些值类型在这两种语言间的对应关系。这些都在头文件jni.h中,用typedef语句声明了这些类在目标平台上的代价类。头文件也定义了常量如:JNI_FALSE=0 和JNI_TRUE=1; 
 表一说明了Java类型和C类型之间的对应关系。 
   表一   Java类型和C类型 
 Java编程语言 C编程语言 字节  
 boolean jboolean 1  
 byte jbyte 1  
 char jchar 2  
 short jshort 2  
 int jint 4  
 long jlong 8  
 float jfloat 4  
 double jdouble 8    
 现在开始对所写的程序进行编译。选择build-> rebuild all对所写的程序进行编译。点击build-> build MyNative.DLL生成DLL文件。 
   也可以用命令行cl来编译。具体参看其他书籍。 
   再次强调(曾经为这个东西大伤脑筋):DLL放置地方 
   1) 当前目录。