Textview与jni没有任何关系

时间:2011-01-06 09:35:24

标签: java android c java-native-interface android-ndk

我想通过Textview显示日志文件,而Textview日志文件内容由jni调用 但Textview没有显示(空白黑屏),当只给出“你好/ n多低”时,Textview显示正确。
return(* env) - > NewStringUTF(env,“hello / n How low”);显示。
return(* env) - > NewStringUTF(env,str);没有显示。

- application.java -

package com.showlog;

import android.app.Activity;
import android.widget.TextView;
import android.os.Bundle;

public class showlog extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        TextView  tv = new TextView(this);
        tv.setText( stringFromJNI() );
        setContentView(tv);
    }

    public native String  stringFromJNI();

    public native String  unimplementedStringFromJNI();

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

- showlog.c -

#include <string.h>
#include <stdio.h>
#include <jni.h>

#define MAX 119 // MAX of one line length of log file
#define Log_file "./Log_file.log" // log file path

jstring
Java_com_showlog_stringFromJNI(JNIEnv* env, jobject thiz)
{
    char line[120]; // one line length of Log_file
    char str[2000]; // Log_file length
    FILE *fin;

    fin=fopen(Log_file, "r");
    while( ! feof(fin)){
        fgets(line, MAX, fin);
        strcat(str, line);
    }
    fclose(fin);

    return (*env)->NewStringUTF(env, str);
}

然后我尝试使用c代码(不是jni lib),它有效 - 显示日志文件 -

#include <string.h>
#include <stdio.h>

#define MAX 119 // MAX of one line length of log file
#define Log_file "./Log_file.log" // log file path

main()
{
    char line[120]; // one line length of Log_file
    char str[2000]; // Log_file length
    FILE *fin;

    fin=fopen(Log_file, "r");
    while( ! feof(fin)){
        fgets(line, MAX, fin);
        strcat(str, line);
    }
    fclose(fin);

        printf("%s", str);

    return 0;
}

Textview如何显示它? 提前谢谢。

1 个答案:

答案 0 :(得分:0)

返回值不正确....只需检查它.....并返回正确的值.....