UnsatisfiedLinkError:setMessageHandler(Native Method)

时间:2013-07-30 07:13:35

标签: android unsatisfiedlinkerror

我正在创建一个应用程序,其中我使用了一些本机方法,这些方法在一个单独的类中定义。当我在Activity类中创建该类的实例时,就会发生这种类型的错误。

这是我的活动类

public class LoginActivity extends Activity
{
        PortSipSdk sdk;
    @Override
    public void onCreate(Bundle savedInstanceState) 
{
        super.onCreate(savedInstanceState);
        setContentView(R.layout.loginview);
        sdk = PortSipSdk.getInstance();//error is occurs at this line
        sdk.setOnRegisterListener(this);
    }
}

Java类是

public class PortSipSdk {
    private final String TAG = "PortSipSdk";
    private static PortSipSdk instance;
    private PortSipNetwork mNetAssist;
    private KeyguardLock mKeyguardLock;

    private Context mContext;

    long mSessionID = PortSipErrorcode.INVALID_SESSION_ID;

    public synchronized static PortSipSdk getInstance() {
        if (instance == null) {
            instance = new PortSipSdk();            
        }
        return instance;
    }

    private PortSipSdk() {
        msgDispatcher = new MainHandler();
        setMessageHandler(msgDispatcher);
        videoRecorder = new PortSipVideoRecoder();
    }


    public native void setMessageHandler(Handler msghandler);

    // Initialize and register functions
    private native int initializeSDK(int enum_transport, String agent,
            String STUNServer, int STUNServerPort);
}

日志

07-30 12:13:01.852: E/AndroidRuntime(651): FATAL EXCEPTION: main
07-30 12:13:01.852: E/AndroidRuntime(651): java.lang.UnsatisfiedLinkError: setMessageHandler
07-30 12:13:01.852: E/AndroidRuntime(651):  at com.portsip.PortSipSdk.setMessageHandler(Native Method)
07-30 12:13:01.852: E/AndroidRuntime(651):  at com.portsip.PortSipSdk.<init>(PortSipSdk.java:62)
07-30 12:13:01.852: E/AndroidRuntime(651):  at com.portsip.PortSipSdk.getInstance(PortSipSdk.java:55)
07-30 12:13:01.852: E/AndroidRuntime(651):  at com.portsip.test.LoginActivity.onCreate(LoginActivity.java:48)
07-30 12:13:01.852: E/AndroidRuntime(651):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
07-30 12:13:01.852: E/AndroidRuntime(651):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
07-30 12:13:01.852: E/AndroidRuntime(651):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
07-30 12:13:01.852: E/AndroidRuntime(651):  at android.app.ActivityThread.access$2300(ActivityThread.java:125)
07-30 12:13:01.852: E/AndroidRuntime(651):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
07-30 12:13:01.852: E/AndroidRuntime(651):  at android.os.Handler.dispatchMessage(Handler.java:99)
07-30 12:13:01.852: E/AndroidRuntime(651):  at android.os.Looper.loop(Looper.java:123)
07-30 12:13:01.852: E/AndroidRuntime(651):  at android.app.ActivityThread.main(ActivityThread.java:4627)
07-30 12:13:01.852: E/AndroidRuntime(651):  at java.lang.reflect.Method.invokeNative(Native Method)
07-30 12:13:01.852: E/AndroidRuntime(651):  at java.lang.reflect.Method.invoke(Method.java:521)
07-30 12:13:01.852: E/AndroidRuntime(651):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
07-30 12:13:01.852: E/AndroidRuntime(651):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
07-30 12:13:01.852: E/AndroidRuntime(651):  at dalvik.system.NativeStart.main(Native Method)

1 个答案:

答案 0 :(得分:0)

确保你的NDK二进制文件在你的APK中。