Android Telegram App --> java.lang.UnsatisfiedLinkError: 未找到 void 的实现

2022-09-01 21:02:29

不幸的是,几周前在Stackoverflow上删除了一个类似的问题,我必须提出一个新问题。

我试图通过source @ https://github.com/DrKLO/Telegram 为Android构建自己的Telegram应用程序

我无法让它工作,它在启动时停止,出现以下错误,任何关于从哪里开始的想法,我对Android Studio很陌生。

11-17 19:55:04.142 2667-2667/org.telegram.messenger E/art: No implementation found for void org.telegram.tgnet.ConnectionsManager.native_setJava(boolean) (tried Java_org_telegram_tgnet_ConnectionsManager_native_1setJava and Java_org_telegram_tgnet_ConnectionsManager_native_1setJava__Z)
11-17 19:55:04.142 2667-2667/org.telegram.messenger D/AndroidRuntime: Shutting down VM
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime: FATAL EXCEPTION: main
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime: Process: org.telegram.messenger, PID: 2667
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime: java.lang.UnsatisfiedLinkError: No implementation found for void org.telegram.tgnet.ConnectionsManager.native_setJava(boolean) (tried Java_org_telegram_tgnet_ConnectionsManager_native_1setJava and Java_org_telegram_tgnet_ConnectionsManager_native_1setJava__Z)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at org.telegram.tgnet.ConnectionsManager.native_setJava(Native Method)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at org.telegram.messenger.ApplicationLoader.onCreate(ApplicationLoader.java:259)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1013)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4707)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at android.app.ActivityThread.-wrap1(ActivityThread.java)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1405)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at android.os.Handler.dispatchMessage(Handler.java:102)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at android.os.Looper.loop(Looper.java:148)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at android.app.ActivityThread.main(ActivityThread.java:5417)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at java.lang.reflect.Method.invoke(Native Method)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
11-17 19:55:04.151 2667-2667/org.telegram.messenger E/AndroidRuntime:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

答案 1

主要问题是,您正在运行项目时没有从 C/C++ 代码生成本机库。由于该项目基于Telegram,您用链接指出它,因此在目录中有文件,您必须手动编译代码。我按照以下步骤修复了该异常:Android.mkjni

  • 包含以下内容的检查:build.gradle

源版本 3.13.1 及更高版本:

sourceSets.main.jniLibs.srcDirs = ['./jni/']

低于 3.13.1 的源版本:

    sourceSets.main {
       jniLibs.srcDirs = 'libs'
       jni.srcDirs = [] //disable automatic ndk-build call
    }

根据您的操作系统继续操作。

Linux / Mac

$ cd <path-to-Telegram>/TMessagesProj
$ <path-to-ndk>/ndk-build

窗户

  • 下载天鹅座
  • 添加文件,该文件放置在Cygwin根目录上(使用一些实用程序来查找该文件)。在我的情况下,该文件被放置在..bashrcC:\cygwin64\home\myuser

    export ndkbuild=/cygdrive/partition_name/your_ndk_directory/ndk-build.cmd
    
  • 打开Cygwin终端,将自己移动到项目的目录:jni

    cd /cygdrive/your_partition_name/project_jni_directory_path
    
  • 编写并等待编译器完成其任务。如果此过程正确,将显示两个目录,以及 。检查目录是否包含一些具有扩展名的库。最后,运行项目。$ndkbuildobjlibslibs.so


答案 2

正如Jesús Castro所提到的,您必须将本机代码编译为带有后缀的库,android可以使用它们来运行应用程序。.so

但是为什么这是最近发生的呢?因为在DrKLO的Telegram存储库的最后一次提交中,他们已经根据git中的提交消息删除了预构建的库:

删除预构建的库。所有库的源代码都可以(并且一直)在这里找到:https://github.com/DrKLO/Telegram/tree/master/TMessagesProj/jni

你可以在这里找到提交。


推荐