- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我一直在将跨平台 C++ 引擎移植到 Android,并注意到它在调用 pthread_mutex_lock 时会莫名其妙地(且不一致地)阻塞。这个引擎已经在几个平台上运行了很多年,而且有问题的代码多年来没有改变,所以我怀疑这是一个死锁或其他错误代码。它必须是我的 Android 端口..
到目前为止,代码中有几个地方阻塞了 pthread_mutex_lock。它也不是完全可复制的。当它挂起时,LogCat 中没有可疑的输出。
我像这样修改了互斥锁代码(为简洁起见进行了编辑...真正的代码检查所有返回值):
void MutexCreate( Mutex* m )
{
#ifdef WINDOWS
InitializeCriticalSection( m );
#else ANDROID
pthread_mutex_init( m, NULL );
#endif
}
void MutexDestroy( Mutex* m )
{
#ifdef WINDOWS
DeleteCriticalSection( m );
#else ANDROID
pthread_mutex_destroy( m, NULL );
#endif
}
void MutexLock( Mutex* m )
{
#ifdef WINDOWS
EnterCriticalSection( m );
#else ANDROID
pthread_mutex_lock( m );
#endif
}
void MutexUnlock( Mutex* m )
{
#ifdef WINDOWS
LeaveCriticalSection( m );
#else ANDROID
pthread_mutex_unlock( m );
#endif
}
我尝试修改 MutexCreate 以进行错误检查和递归互斥锁,但这并不重要。我什至没有收到错误或日志输出,所以这要么意味着我的互斥代码很好,要么没有显示错误/日志。操作系统如何准确地通知您错误的互斥锁使用情况?
引擎大量使用静态变量,包括互斥量。我看不出如何,但这是一个问题吗?我对此表示怀疑,因为我修改了很多互斥量以改为在堆上分配,并且发生了相同的行为。但这可能是因为我错过了一些静态互斥锁。我可能正在捕获这里的救命稻草。
我阅读了一些引用资料,包括:
http://pubs.opengroup.org/onlinepubs/7908799/xsh/pthread_mutex_init.html
http://www.embedded-linux.co.uk/tutorial/mutex_mutandis
最佳答案
“errorcheck”互斥锁会检查一些事情(比如尝试递归地使用非递归互斥锁)但没什么了不起的。
你说“真实代码检查所有返回值”,所以如果任何 pthread 调用返回非零值,你的代码可能会爆炸。 (不确定为什么你的 pthread_mutex_destroy 需要两个参数;假设复制和粘贴错误。)
pthread 代码在 Android 中广泛使用并且没有已知的挂断,因此问题不太可能出现在 pthread 实现本身。
互斥量的当前实现适合 32 位,因此如果您打印 *(pthread_mutex_t* mut)
作为整数,您应该能够弄清楚它处于什么状态(从技术上讲,它是什么状态曾经在过去的某个时候)。 bionic/libc/bionic/pthread.c中的定义是:
/* a mutex is implemented as a 32-bit integer holding the following fields
*
* bits: name description
* 31-16 tid owner thread's kernel id (recursive and errorcheck only)
* 15-14 type mutex type
* 13 shared process-shared flag
* 12-2 counter counter of recursive mutexes
* 1-0 state lock state (0, 1 or 2)
*/
“快速”互斥锁的类型为 0,并且不设置 tid
字段。事实上,通用互斥量的值为 0(未保留)、1(保留)或 2(保留,有争用)。如果您曾经看到一个快速互斥锁,其值不是其中之一,很可能是有什么东西出现并踩到了它。
这也意味着,如果您将程序配置为使用递归互斥锁,您可以通过拉出位来查看哪个线程持有互斥锁(通过在 trylock 指示您即将停止或转储时打印互斥锁值)在挂起的进程上使用 gdb 状态)。那加上 ps -t
的输出,会让您知道锁定互斥锁的线程是否仍然存在。
关于android NDK互斥锁定,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13755355/
我想使用 ndk 构建一个 3rd 方库 avahi。 avahi 已经有 android 端口(带有有效的 Android.mk)。 我做了什么: 我已经成功创建了一个项目并将所有源代码复制到 jn
由于不再需要Android NDK,因此我尝试将其卸载。在Eclipse中找到的路径似乎已损坏。我应该如何清理这个烂摊子?我尝试了brew,但它说未安装NDK。 (它甚至告诉我未安装SDK!也许不是通
我是 Android Studio 和 Android NDK 的新手。我正在尝试使用 android NDK 为类分配编译一个简单的 hello.c 程序。我已按照以下项目说明进行操作,但出现错误:
当我尝试执行 NDK 构建时,我收到以下错误列表...有人知道吗? encies\FreeImage/D:/Projects.CPP/Engine5/svn/trunk/Dependencies/Fr
我正在使用 android-ndk-profiler-3.1 为我的项目进行 NDK 分析。我在 Android.mk 中进行了如下更改... LOCAL_PATH := $(call my-dir)
我需要使用 cutils 库和头文件在我的 NDK 项目中实现 ashmem,但我在我的系统中找不到与 cutils 相关的任何内容。它位于何处或从何处获得? 最佳答案 Android“cutils”
我有两个独立的项目,一个项目用于构建 Boost 库,另一个项目从构建的 boost 库中调用。 Boost 项目编译良好并生成 libboost.a 文件。我想要实现的是将此库添加到我的其他 NDK
我在ndk-build clean上遇到以下错误 mo@mo-Toshiba ~/Workspace/AndroidApp/jni/android_programming_driver $ ndk-b
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我正在尝试使用 NDK(又使用开放 SLES)在 Android 上创建一个基于流的音频应用程序。我已经完成了基本的流媒体设置。我需要知道 Android 中如何处理欠载(或重载)?错误回调是如何实现
我的 Application.mk 设置为构建 arm 以及 x86 共享库: APP_ABI :- armeabi-v7a x86 我有预建的 openssl 静态库: libcrypto_v7a.
我的 $NDK_HOME 文件夹包含标准库的不同实现。 qdii@nomada /opt/android-ndk/platforms $ ls -l total 24 drwxr-xr-x 5 roo
如何安装android-ndk。我已经为 ndk 设置了路径,但在执行“ndk-build”命令时仍然出现错误。 fya 我正在使用 Windows 操作系统。 最佳答案 它对我有用: 打开命令提示符
构建 Android-ndk 时出现以下错误 请帮助我。 Cygwin.bat @echo off set IS_UNIX= set DEV_ROOT=C:/iliu-Android-NDK-Fibo
我开始使用 android ndk (r8c),为此我安装了新版本的 Ubuntu 12.10 (32bit) 问题,无论我尝试构建什么,我都会遇到让我发疯的怪异错误...... ~/workspac
我正在尝试向我的 Android 项目添加 Crashlytics 支持,该项目使用 NDK 和 gradle CMake。这意味着我的共享项目需要符号。所以如果我想为发布版本创建符号,我会调用 gr
我想知道是否有人设法使用 Android NDK(r8d) 的工具链构建了新的 SDL2。 SDL2 似乎非常接近发布(从昨天开始,它不再是“正在 build 中:http://hg.libsdl.o
我试图在“ndk-build”过程中禁用所有警告,以编译与 Android 上的 JNI 一起使用的 CPP 代码。 我正在使用 LOCAL_CFLAGS := -Wno-error没有成功。 有任何
谁能告诉我如何在android(ndk-build)中建立C-ares库 最佳答案 这是使用NDK standalone toolchain将其构建为ARMv7的静态库的方法: export NDK=
我正在尝试从我的 native 代码中读取一个简单的文本文件。 我把file.txt放在assets文件夹下 在我的事件中,我正在创建 Assets 管理器:assetManager = getAss
我是一名优秀的程序员,十分优秀!