Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/232.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 我的应用程序失败了,我不知道为什么_Android_Android Ndk - Fatal编程技术网

Android 我的应用程序失败了,我不知道为什么

Android 我的应用程序失败了,我不知道为什么,android,android-ndk,Android,Android Ndk,我正在按照本文中的指导原则编写一个非常简单的应用程序 我试图运行我的应用程序,但它在打开时失败。编写的C代码是使用ndk build编译的 以下是Java代码: package com.example.ndktest; import android.os.Bundle; import android.app.Activity; import android.util.Log; import android.view.Menu; import android.view.MenuItem; imp

我正在按照本文中的指导原则编写一个非常简单的应用程序

我试图运行我的应用程序,但它在打开时失败。编写的C代码是使用
ndk build
编译的

以下是Java代码:

package com.example.ndktest;

import android.os.Bundle;
import android.app.Activity;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.support.v4.app.NavUtils;

public class MainActivity extends Activity {


    private Button button;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Log.i( "MainActivity", "beginning of onCreate()" );
        setContentView(R.layout.activity_main);

        button = (Button) findViewById( R.id.button1 );
        button.setOnClickListener( new OnClickListener( ) {

        public void onClick(View arg0) {
            // TODO Auto-generated method stub
            helloLog( "This will log to LogCat" );
        }

        });
    }
    private native void helloLog( String logThis );

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

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }   
}
下面是C代码:

#include <jni.h>
#include <string.h>
#include <android/log.h>

#define DEBUG_TAG "NDK_AndroidNDK1SampleActivity"

void Java_com_example_ndktest_MainActivity_helloLog( JNIEnv * env, jobject this, jstring logThis )
{
    jboolean isCopy;
    const char * szLogThis = (*env)->GetStringUTFChars( env, logThis, &isCopy );

    __android_log_print( ANDROID_LOG_DEBUG, DEBUG_TAG, "NDK:LC: [%s]", szLogThis );

    (*env)->ReleaseStringUTFChars( env, logThis, szLogThis );
}
以下是XML文件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:padding="@dimen/padding_medium"
        android:text="@string/hello_world"
        tools:context=".MainActivity" />

    <Button
        android:id="@+id/button1"
        android:layout_width="fill_parent"
        android:text="Click Here to Log" />

</RelativeLayout>

以下是AndroidManifest:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.ndktest"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/title_activity_main" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

以下是我在Eclipse中的环境图片:

编辑:

发现LogCat确实显示了一些东西,但它们被过滤器隐藏了…仍然无法找出问题所在。下面是日志:

07-30 15:22:31.718: E/AndroidRuntime(2589): FATAL EXCEPTION: main
07-30 15:22:31.718: E/AndroidRuntime(2589): java.lang.ExceptionInInitializerError
07-30 15:22:31.718: E/AndroidRuntime(2589):     at java.lang.Class.newInstanceImpl(Native Method)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at java.lang.Class.newInstance(Class.java:1409)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1561)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at android.os.Handler.dispatchMessage(Handler.java:99)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at android.os.Looper.loop(Looper.java:130)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at android.app.ActivityThread.main(ActivityThread.java:3683)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at java.lang.reflect.Method.invokeNative(Native Method)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at java.lang.reflect.Method.invoke(Method.java:507)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at dalvik.system.NativeStart.main(Native Method)
07-30 15:22:31.718: E/AndroidRuntime(2589): Caused by: java.lang.UnsatisfiedLinkError: Couldn't load ndk1: findLibrary returned null
07-30 15:22:31.718: E/AndroidRuntime(2589):     at java.lang.Runtime.loadLibrary(Runtime.java:429)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at java.lang.System.loadLibrary(System.java:554)
07-30 15:22:31.718: E/AndroidRuntime(2589):     at com.example.ndktest.MainActivity.<clinit>(MainActivity.java:38)
07-30 15:22:31.718: E/AndroidRuntime(2589):     ... 15 more
07-30 15:22:31.718: W/ActivityManager(1136):   Force finishing activity com.example.ndktest/.MainActivity
07-30 15:22:31.718:E/AndroidRuntime(2589):致命异常:main
07-30 15:22:31.718:E/AndroidRuntime(2589):java.lang.ExceptionInInitializeError
07-30 15:22:31.718:E/AndroidRuntime(2589):位于java.lang.Class.newInstanceImpl(本机方法)
07-30 15:22:31.718:E/AndroidRuntime(2589):位于java.lang.Class.newInstance(Class.java:1409)
07-30 15:22:31.718:E/AndroidRuntime(2589):在android.app.Instrumentation.newActivity(Instrumentation.java:1021)上
07-30 15:22:31.718:E/AndroidRuntime(2589):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1561)
07-30 15:22:31.718:E/AndroidRuntime(2589):位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
07-30 15:22:31.718:E/AndroidRuntime(2589):在android.app.ActivityThread.access$1500(ActivityThread.java:117)
07-30 15:22:31.718:E/AndroidRuntime(2589):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
07-30 15:22:31.718:E/AndroidRuntime(2589):在android.os.Handler.dispatchMessage(Handler.java:99)上
07-30 15:22:31.718:E/AndroidRuntime(2589):在android.os.Looper.loop(Looper.java:130)
07-30 15:22:31.718:E/AndroidRuntime(2589):在android.app.ActivityThread.main(ActivityThread.java:3683)上
07-30 15:22:31.718:E/AndroidRuntime(2589):位于java.lang.reflect.Method.Invokenactive(本机方法)
07-30 15:22:31.718:E/AndroidRuntime(2589):位于java.lang.reflect.Method.invoke(Method.java:507)
07-30 15:22:31.718:E/AndroidRuntime(2589):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
07-30 15:22:31.718:E/AndroidRuntime(2589):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
7-30 15:22:31.718:E/AndroidRuntime(2589):在dalvik.system.NativeStart.main(本机方法)
07-30 15:22:31.718:E/AndroidRuntime(2589):原因:java.lang.UnsatifiedLink错误:无法加载ndk1:findLibrary返回null
07-30 15:22:31.718:E/AndroidRuntime(2589):在java.lang.Runtime.loadLibrary(Runtime.java:429)上
07-30 15:22:31.718:E/AndroidRuntime(2589):位于java.lang.System.loadLibrary(System.java:554)
07-30 15:22:31.718:E/AndroidRuntime(2589):位于com.example.ndktest.MainActivity。(MainActivity.java:38)
2007-30 15:22:31.718:E/AndroidRuntime(2589):。。。还有15个
07-30 15:22:31.718:W/ActivityManager(1136):强制完成活动com.example.ndktest/.MainActivity
编辑2:

以下是我调用ndk build后cygwin终端的图片:


很可能是库
libndk1。因此
活动无法加载
。你确定
libndk1.so
builds很好吗

by: java.lang.UnsatisfiedLinkError: Couldn't load ndk1: findLibrary returned null

再次查看帖子,我在ndk build命令后添加了一张Cygwin终端的图片。@JuiCe为什么上次的操作是“干净的”Clean'删除libndk1.so,那么您的活动将找不到它。我不知道,我认为这是一个可行的选择。我尝试了ndk build并重新运行了它,但它仍然给了我同样的错误。@JuiCe您是否喜欢1)clean 2)ndk build 3)在Eclipse项目中执行clean并等待项目重建。因为Eclipse不知道您刚刚重建了libndk1。so@JuiCe那我真的不知道。您可能可以从ndk获取hello jni样本,然后让它工作起来。该示例与您的代码几乎相同
by: java.lang.UnsatisfiedLinkError: Couldn't load ndk1: findLibrary returned null