- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经搜索过堆栈溢出,但没有一个能真正解决我的问题。
我能够为我的库构建 .so 文件并将其加载到 jniLibs 目录中。当我运行应用程序时,我得到了这个
java.lang.UnsatisfiedLinkError: Native method not found: soundtouch.ST.setup:(IIIIFF)V 在 soundtouch.ST.setup( native 方法)
我折腾了2天,还是没搞清楚问题所在。请有人指导我解决这个问题。
我在这里错过了什么?
谢谢!我的构建.gradle:
apply plugin: 'com.android.application'
android {
compileSdkVersion 21
buildToolsVersion "21.1.2"
defaultConfig {
applicationId "com.examples.anu.soundtouchexamplewithseekbar"
minSdkVersion 19
targetSdkVersion 21
versionCode 1
versionName "1.0"
ndk {
moduleName "soundtouch-jni"
}
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
}
}
sourceSets.main {
jniLibs.srcDir 'src/main' //set .so files location to libs
jni.srcDirs = [] //disable automatic ndk-build call
}
tasks.withType(JavaCompile) {
compileTask -> compileTask.dependsOn ndkBuild
}
task ndkBuild(type: Exec, description: 'Compile JNI source via NDK') {
def ndkDir = project.plugins.findPlugin('com.android.application').getNdkFolder()
commandLine "$ndkDir/ndk-build",
'NDK_PROJECT_PATH=build/intermediates/ndk',
'NDK_LIBS_OUT=src/main/jniLibs',
'APP_BUILD_SCRIPT=src/main/jni/Android.mk',
'NDK_APPLICATION_MK=src/main/jni/Application.mk'
}
}
dependencies
{
compile fileTree(dir: 'libs', include: ['*.jar'])
compile fileTree(include: ['*.jar'], dir: 'src/main/jniLibs')
compile 'com.android.support:appcompat-v7:21.0.3'
}
我的 Android.mk:
LOCAL_PATH := $(call my-dir)
APP_STL := stlport_shared
include $(CLEAR_VARS)
MY_SOURCE_DIR:=soundtouch
LOCAL_MODULE:=soundtouch-jni
LOCAL_C_INCLUDES:=$(LOCAL_PATH)/soundtouch/include
LOCAL_SRC_FILES:= soundtouch_ST.cpp\
soundtouch-jni.cpp\
$(MY_SOURCE_DIR)/source/SoundTouch/AAFilter.cpp\
LOCAL_ARM_MODE:=arm
LOCAL_LDLIBS+=-lz -llog
LOCAL_CFLAGS += -Wall -fvisibility=hidden -I soundtouch/source/../include -D ST_NO_EXCEPTION_HANDLING -fdata-sections -ffunction-sections
include $(BUILD_SHARED_LIBRARY)
========部分添加我的 java 和 JNI 签名:
import android.util.Log;
public class ST implements AudioProcessor
{
private static final int DEFAULT_BUFFER_SIZE = 2048;
private static synchronized native final void putBytes(int track,
byte[] input, int length);
private static synchronized native final void setup(int track,
int channels, int samplingRate, int bytesPerSample, float tempo,float pitchSemi);
==========我的自动生成:.h 文件: /* 不要编辑这个文件 - 它是机器生成的 / #包括 / 类 soundtouch_ST 的标题 */
#ifndef _Included_soundtouch_ST
#define _Included_soundtouch_ST
#ifdef __cplusplus
extern "C" {
#endif
#undef soundtouch_ST_DEFAULT_BUFFER_SIZE
#define soundtouch_ST_DEFAULT_BUFFER_SIZE 2048L
/*
* Class: soundtouch_ST
* Method: clearBytes
* Signature: (I)V
*/
JNIEXPORT void JNICALL Java_soundtouch_ST_clearBytes
(JNIEnv *, jclass, jint);
/*
* Class: soundtouch_ST
* Method: finish
* Signature: (II)V
*/
JNIEXPORT void JNICALL Java_soundtouch_ST_finish
(JNIEnv *, jclass, jint, jint);
/*
* Class: soundtouch_ST
* Method: getBytes
* Signature: (I[BI)I
*/
JNIEXPORT jint JNICALL Java_soundtouch_ST_getBytes
(JNIEnv *, jclass, jint, jbyteArray, jint);
/*
* Class: soundtouch_ST
* Method: putBytes
* Signature: (I[BI)V
*/
JNIEXPORT void JNICALL Java_soundtouch_ST_putBytes
(JNIEnv *, jclass, jint, jbyteArray, jint);
/*
* Class: soundtouch_ST
* Method: setup
* Signature: (IIIIFF)V
*/
JNIEXPORT void JNICALL Java_soundtouch_ST_setup
(JNIEnv *, jclass, jint, jint, jint, jint, jfloat, jfloat);
====== 我的实现:soundtouch_ST.cpp
#include "soundtouch_ST.h"
#include "soundtouch-jni.h"
/* cpp for class soundtouch_ST */
#ifndef _Included_soundtouch_ST
#define _Included_soundtouch_ST
#ifdef __cplusplus
extern "C" {
SoundTouchStream sts = new SoundTouchStream();
#endif
/ *
* Class: soundtouch_ST
* Method: clearBytes
* Signature: (I)V
*/
JNIEXPORT void JNICALL Java_soundtouch_ST_clearBytes
(JNIEnv *env, jclass obj, jint track) {
sts->clearBytes(env,obj,track);
}
/*
* Class: soundtouch_ST
* Method: finish
* Signature: (II)V
*/
JNIEXPORT void JNICALL Java_soundtouch_ST_finish
(JNIEnv *, jclass obj, jint track, jint length){
sts->finish(env,obj,track,length);
}
/*
* Class: soundtouch_ST
* Method: getBytes
* Signature: (I[BI)I
*/
JNIEXPORT jint JNICALL Java_soundtouch_ST_getBytes
(JNIEnv *env, jclass obj, jint a, jbyteArray x, jint b) {
(*env)->sts->getBytes(env,obj,a,x,b);
}
/*
* Class: soundtouch_ST
* Method: putBytes
* Signature: (I[BI)V
*/
JNIEXPORT void JNICALL Java_soundtouch_ST_putBytes
(JNIEnv *env, jclass obj, jint a, jbyteArray x, jint b) {
sts->putBytes(env,obj,a,x,b);
}
/*
* Class: soundtouch_ST
* Method: setup
* Signature: (IIIIFF)V
*/
JNIEXPORT void JNICALL Java_soundtouch_ST_setup
(JNIEnv *env, jclass obj, jint a, jint b, jint c, jint d, jfloat f, jfloat g) {
sts->setup(env,obj,a,b,c,d,f,g)
}
最佳答案
它是以下之一:
1) 不包括您的图书馆。解压缩 apk 并确保它在里面。
2)你没有加载.so文件
3)C 端和 Java 端的 JNI 函数签名不匹配(错误是期望它按顺序接受 4 个整数和 2 个 float 并返回 void)。
4)您在 Java 或 C 中打错了名称,因此它们不匹配。
关于android - java.lang.UnsatisfiedLinkError : Native method not found: soundtouch. ST.setup :(IIIIFF)V at soundtouch. ST.setup(本地方法),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29022594/
这段代码无法编译: for(vector::iterator it = shapes.end(); it >= shapes.begin(); --it){ *it.update(1,1);
我一直在研究 Common Lisp 对象协议(protocol) (CLOS),我遇到了一个疑问。 有人知道 CLOS 中的“标准方法组合”和“简单方法组合”是什么意思吗? 在“简单方法组合”中,“
在Rust上对值调用方法之间是否有任何区别,如下所示: struct A { e: u32 } impl A { fn show(&self) { println!("{}",
我在一些 StackOverflow 答案中看到了术语抽象方法、具体方法和默认方法的“不同”定义。 Java 语言规范给出的真正定义是什么?请在您的答案中包含相关的支持 JLS 引用资料。 最佳答案
如果method = "post",如何使rest[method]扩展为rest.post(uri, body).then(. .? function proxyUrl() { return
这个问题在这里已经有了答案: Method cannot be translated into a store expression (1 个回答) 关闭 9 年前。 我有一个问题。我在 Visua
它们各自的优缺点是什么? 接口(interface)方法 虚方法 抽象方法 什么时候应该选择什么?做出这一决定时应牢记哪些要点? 最佳答案 虚拟和抽象几乎是一样的。虚方法在基类中有一个可以选择被覆盖的
我在 Meteor.js 上的那段代码出错: 客户端 : Meteor.call("logUser", function(myvar){ console.log("le c
运行代码时出现以下错误 Line: 18 illegal start of expression Line: 18 ';' expected 这意味着第 18 行中有代码写得不正确(public bo
如果可能的话,如何从另一个方法的返回中调用一个方法? 例如…… class Example { public static void main(String[] args) {
当遍历指针的 vector (或其他容器)时,使用以下优势和/或优势之间是否有任何区别: for (it = v.begin(); it != v.end(); ++it) { (*it)->
在从带有参数的 void 方法打印值或将值返回给方法调用者并在方法调用者中打印它之间,哪个被认为是更好的做法(如果有的话)?比如第一个代码摘录是前者,第二个代码摘录是后者: public static
考虑这个例子https://codesandbox.io/s/1yvp4zz5x7?module=%2Fsrc%2FApp.vue Greet1 Greet2
晚上好, 我刚开始使用 Microsoft.Contracts(最新版本)并将其插入示例界面之上,现在它看起来像这样: namespace iRMA2.Core.Interfaces { us
我是 Laravel 4 的新手,并试图弄清楚为什么我收到一个错误,说 Method [show] 不存在。 我没有名为“show”的方法,只能想象这是一个内部的 Laravel 方法,但我不知道如何
有人可以向我解释一下当我们进行下一次返回时“或”(||) 是什么意思吗? 我的意思是这行: 返回封面(值,金额 - 值 [索引],索引 + 1)||覆盖(值、金额、索引 + 1); public st
这个问题已经有答案了: Why doesn't the post increment operator work on a method that returns an int? (11 个回答) 已
我很难理解 jQuery 的 $.method() 和 $(selector).method 之间的区别。 $.method() 实际适用于 DOM 中的哪些元素?如果有人能帮助解释这两种说法之间的区
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 5 年前。 Improve t
////////////////////////////////////////////////////////////////////////////// // 3 construct
我是一名优秀的程序员,十分优秀!