Java 编译,"No such file or Directory"

Java compiling, "No such file or Directory"

我正在尝试使用 JNI 让 C 程序在 java 下运行。问题来了。

首先我创建了 java class testcli.java:

public class testcli {

    public native void stdErr();
    public native int cliFromC();


    static {
        System.loadLibrary("ctest"); 
    }

    public static void main(String[] args) {

        new testcli().stdErr();
        new testcli().cliFromC();

    }

然后用

编译
javac testcli.java

并用

创建了header
javah testcli

之后创建库 ctest.c 并使用

编译
gcc -o libctest.so -shared -I/path/to/jni.h ctest.c -lc

我创建了 libctest.so,然后将以下代码添加到 bashrc 中:

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:~/Desktop/project2/thesys/src

当我去打字时

java testcli

它说我 "No such file or directory"。

我是 运行 java 32 位机器上的 8 oracle,xubuntu 32 位。有什么想法吗?

编辑:在此处添加 ctest.c 代码(我认为此处可能存在一些错误)

#include <jni.h>
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <sys/wait.h>
#include <sys/socket.h>
#include <signal.h>
#include <ctype.h>          
#include <arpa/inet.h>
#include <netdb.h>


#define PORT 20000
#define LENGTH 512 

JNIEXPORT void JNICALL Java_testcli_stdErr
  (JNIEnv *env, jobject jobj)

{
    const char *msg = NULL;

    perror(msg);
    exit(1);
}

JNIEXPORT jint JNICALL Java_testcli_cliFromC
  (JNIEnv *env, jobject jobj)

{
    /* Variable Definition */
    int sockfd; 
    int nsockfd;
    char revbuf[LENGTH]; 
    struct sockaddr_in remote_addr;
    //struct hostent *server; // per la parte scritta da me

    /* Get the Socket file descriptor */
    if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1)
    {
        fprintf(stderr, "ERROR: Failed to obtain Socket Descriptor! (errno = %d)\n",errno);
        exit(1);
    }


    /* Fill the socket address struct */
    remote_addr.sin_family = AF_INET; 
    remote_addr.sin_port = htons(PORT); 

    /*questo lo faccio così perchè localhost è 127.0.0.1, nel caso in cui debba recuperare l'ip dall'hostname uso la parte commentata sopra*/
    inet_pton(AF_INET, "127.0.0.1", &remote_addr.sin_addr); //metto in remote_addr.sin_addr l'indirizzo ip 127.0.0.1 nel formato desiderato



    bzero(&(remote_addr.sin_zero), 8);

    /* Try to connect the remote */
    if (connect(sockfd, (struct sockaddr *)&remote_addr, sizeof(struct sockaddr)) == -1)
    {
        fprintf(stderr, "ERROR: Failed to connect to the host! (errno = %d)\n",errno);
        exit(1);
    }
    else 
        printf("[Client] Connected to server at port %d...ok!\n", PORT);

/* Send File to Server */
    //if(!fork())
    //{
        char* fs_name = "/home/elia/Desktop/project/tesi/PublicKey1";
        char sdbuf[LENGTH]; 
        printf("[Client] Sending %s to the Server... ", fs_name);
        FILE *fs = fopen(fs_name, "r");
        if(fs == NULL)
        {
            printf("ERROR: File %s not found.\n", fs_name);
            exit(1);
        }

        bzero(sdbuf, LENGTH); 
        int fs_block_sz; 
        while((fs_block_sz = fread(sdbuf, sizeof(char), LENGTH, fs)) > 0)
        {
            if(send(sockfd, sdbuf, fs_block_sz, 0) < 0)
            {
                fprintf(stderr, "ERROR: Failed to send file %s. (errno = %d)\n", fs_name, errno);
                break;
            }
            bzero(sdbuf, LENGTH);
        }
        printf("Ok File %s from Client was Sent!\n", fs_name);
    //}
    close (sockfd);
    printf("[Client] Connection lost.\n");
    return (0);

}   

其实,一切都很好。该错误来自您的 stdErr() 函数,它实际上表明它正在运行。我犯了同样的错误。为什么会这样?

const char *msg = NULL;

perror(msg);
exit(1);

这会打印程序中导致的最后一个错误。现在,如果您的程序确实有错误,您应该只使用 perror()。否则,它将打印之前 errno 变量中的任何信息。

errno 可能是由 Java 内部的某些东西设置的。它可能一直在寻找一些文件,但它的不存在对 Java 来说不是问题,所以它继续工作。但是 errno 被设置为该值并保持该值,这就是您程序中打印的内容。

为了证明这一点,我在您的 testcli.java 中添加了以下内容:

public native void clearErr();

而我的 main 是:

public static void main(String[] args) {

    new testcli().clearErr();
    new testcli().stdErr();
    new testcli().cliFromC();

}

我在 ctest.c 中添加了:

JNIEXPORT void JNICALL Java_testcli_clearErr
  (JNIEnv *env, jobject jobj)

{
    errno = 0;
}

再次执行 javacjavahgcc,运行 程序,现在我得到:

Success

请注意,由于 stdErr() 中的 exit(),您的第三个方法未被调用。