Не удается разрешить соответствующую функцию JNI Java_com_mozilla_greetings_RustGreetings_greeting - PullRequest
0 голосов
/ 25 ноября 2018

Я пытаюсь скопировать этот учебник для сборки и использования Rust lib в приложении Android, я успешно собираю библиотеку и загрузил сгенерированные библиотеки здесь

Функция, которую Android должен вызывать с помощью темы Java_<Package>_Class_function:

Java_com_mozilla_greetings_RustGreetings_greeting

Структура моего приложения для Android выглядит следующим образом:

enter image description here

Я получаю приведенную ниже ошибку в своей оболочке JNI:

Невозможно разрешить соответствующую функцию JNI Java_com_mozilla_greetings_RustGreetings_greeting

Упаковка JNI:

package com.mozilla.greetings;

public class RustGreetings {

    private static native String greeting(final String pattern);

    public String sayHello(String to) {
        return greeting(to);
    }
}

А основной класс это:

package com.mozilla.greetings;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.TextView;

public class GreetingsActivity extends AppCompatActivity {

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

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_greetings);

        RustGreetings g = new RustGreetings();
        String r = g.sayHello("world");
        ((TextView) findViewById(R.id.greetingField)).setText(r);
    }
}

1 Ответ

0 голосов
/ 25 ноября 2018

Я решил это, используя JNA, который, по-моему, медленнее JNI, я напишу свое решение ниже, используя JNA, надеясь, что кто-то предоставит необходимое исправление, используя JNI

Моя структура приложениякак показано ниже, используя kotlin:

  • Я добавил libjnidispatch.so в каждую папку сборки библиотеки, это можно получить путем извлечения требуемой архитектуры Android из здесь , скачатьнеобходимую банку, затем извлеките ее, чтобы получить libjnidispatch.so
  • Я создал интерфейс для jna

JNA.kt

package com.mozilla.greetings

import com.sun.jna.Library

   interface JNA : Library {
      fun rust_greeting(pattern: String): String
   }

Я создал оболочку для jna, RustGreetings.kt:

package com.mozilla.greetings

import com.sun.jna.Native

class RustGreetings {

fun sayHello(to: String): String =
        Native.loadLibrary<JNA>("greetings", JNA::class.java).rust_greeting(to)
}

Основная деятельность, GreetingsActivity.kt:

package com.mozilla.greetings

import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import kotlinx.android.synthetic.main.activity_greetings.*


class GreetingsActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_greetings)

    val g = RustGreetings()
    val r = g.sayHello("Rust")
    greetingField.text = r
}

companion object {
    init {
        System.loadLibrary("greetings")
    }
}
}

Примечание: во избежание использования findViewById я использовал расширение kotlin, как объяснено здесь и добавив ниже к build.gradle (модуль):

apply plugin: 'kotlin-android-extensions'

ОБНОВЛЕНИЕ

Похоже, что IDE ничего не значит с кодом, приложение было выполнено.Я переписал его, используя Kotlin, и он также был выполнен гладко, под моим кодом kotlin:

GreetingsActivity.kt

package com.mozilla.greetings

import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import kotlinx.android.synthetic.main.activity_greetings.*

class GreetingsActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_greetings)

        val g = RustGreetings()
        val r = g.sayHello("My Rust")
        greetingField.text = r
    }

    companion object {

        init {
            System.loadLibrary("greetings")
        }
    }
}

RustGreetings.kt

package com.mozilla.greetings

class RustGreetings {

    private external fun greeting(pattern: String): String

    fun sayHello(to: String): String = greeting(to)
}

build.gradle

apply plugin: 'com.android.application'
apply plugin: 'kotlin-android-extensions'

apply plugin: 'kotlin-android'

apply plugin: 'kotlin-android-extensions'

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "com.mozilla.greetings"
        minSdkVersion 28
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation"org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}

activity_greetings.xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".GreetingsActivity">

    <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Hello World!"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent" android:id="@+id/greetingField"/>

</android.support.constraint.ConstraintLayout>

Ниже структуры и исполнения, apk здесь :

enter image description here

...