- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在 android 8.1.0 中遇到了 opensl es 崩溃。
相关代码:
TEResult SLESAudioEngine::release(TEMsg *pMsg) {
TEResult ret;
SLuint32 playState = 0;
(*bqPlayerPlay)->GetPlayState(bqPlayerPlay, &playState);
LOGE(LOG_TAG, "%s, %d, %d", __FUNCTION__, __LINE__, playState);
if (bqPlayerPlay != nullptr) {
SLresult slRet = (*bqPlayerPlay)->SetPlayState(bqPlayerPlay, SL_PLAYSTATE_STOPPED);
if (slRet != SL_RESULT_SUCCESS) {
LOGE(LOG_TAG, "%s,%d SetPlayState failed %d", __FUNCTION__, __LINE__, ret);
return slRet;
}
bqPlayerPlay = nullptr;
}
if (bqPlayerBufferQueue != nullptr) {
SLresult slRet = (*bqPlayerBufferQueue)->Clear(bqPlayerBufferQueue);
if (slRet != SL_RESULT_SUCCESS) {
LOGE(LOG_TAG, "GetInterface BufferQueueItf failed %d", ret);
return slRet;
}
bqPlayerBufferQueue = nullptr;
}
if (bqPlayerObject != nullptr) {
(*bqPlayerObject)->Destroy(bqPlayerObject);
bqPlayerObject = nullptr;
}
if (outputMixObject != NULL) {
(*outputMixObject)->Destroy(outputMixObject);
outputMixObject = NULL;
}
LOGE(LOG_TAG, "%s %d Destroy", __FUNCTION__, __LINE__);
// destroy engine object, and invalidate all associated interfaces
if (engineObject != NULL) {
(*engineObject)->Destroy(engineObject);
engineObject = NULL;
}
return ret;
}
相关日志:
11-05 15:17:58.270 F/DEBUG ( 5887): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
11-05 15:17:58.270 F/DEBUG ( 5887): Build fingerprint: 'vivo/PD1806/PD1806:8.1.0/OPM1.171019.019/compil08312141:user/release-keys'
11-05 15:17:58.270 F/DEBUG ( 5887): Revision: '0'
11-05 15:17:58.270 F/DEBUG ( 5887): ABI: 'arm'
11-05 15:17:58.270 F/DEBUG ( 5887): pid: 5609, tid: 5835, name: jerikc.demo.app >>> com.jerikc.demo.app <<<
11-05 15:17:58.270 F/DEBUG ( 5887): signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 0x0
11-05 15:17:58.270 F/DEBUG ( 5887): Cause: null pointer dereference
11-05 15:17:58.270 F/DEBUG ( 5887): r0 fffffffe r1 00000000 r2 c164d407 r3 f18e1e30
11-05 15:17:58.270 F/DEBUG ( 5887): r4 00002282 r5 f18e1da9 r6 f3e66dfc r7 00000000
11-05 15:17:58.270 F/DEBUG ( 5887): r8 f3a66704 r9 000015e9 sl d148808d fp ced2aa80
11-05 15:17:58.270 F/DEBUG ( 5887): ip 00000001 sp c9b95550 lr f18e1e07 pc f3dd0482 cpsr 880f0030
11-05 15:17:58.310 F/DEBUG ( 5887):
11-05 15:17:58.310 F/DEBUG ( 5887): backtrace:
11-05 15:17:58.310 F/DEBUG ( 5887): #00 pc 000bc482 /system/lib/libandroid_runtime.so (android::proxy_cleanup(void const*, void*, void*)+65)
11-05 15:17:58.310 F/DEBUG ( 5887): #01 pc 00040787 /system/lib/libbinder.so (android::BpBinder::ObjectManager::kill()+30)
11-05 15:17:58.310 F/DEBUG ( 5887): #02 pc 00040745 /system/lib/libbinder.so (android::BpBinder::ObjectManager::~ObjectManager()+4)
11-05 15:17:58.310 F/DEBUG ( 5887): #03 pc 000410b9 /system/lib/libbinder.so (android::BpBinder::~BpBinder()+124)
11-05 15:17:58.310 F/DEBUG ( 5887): #04 pc 00041125 /system/lib/libbinder.so (android::BpBinder::~BpBinder()+12)
11-05 15:17:58.310 F/DEBUG ( 5887): #05 pc 00040547 /system/lib/libbinder.so (android::BpRefBase::~BpRefBase()+46)
11-05 15:17:58.310 F/DEBUG ( 5887): #06 pc 00004633 /system/lib/libaudiomanager.so (_ZTv0_n12_N7android14BpAudioManagerD0Ev+22)
11-05 15:17:58.310 F/DEBUG ( 5887): #07 pc 0000dc5f /system/lib/libwilhelm.so (android::sp<android::TrackPlayerBase>::clear()+18)
11-05 15:17:58.310 F/DEBUG ( 5887): #08 pc 00016a2f /system/lib/libwilhelm.so (CEngine_Destroy(void*)+198)
11-05 15:17:58.310 F/DEBUG ( 5887): #09 pc 0001b975 /system/lib/libwilhelm.so (IObject_Destroy(SLObjectItf_ const* const*)+204)
11-05 15:17:58.310 F/DEBUG ( 5887): #10 pc 001c197f /data/app/com.jerikc.demo.app-4ZSXR9PUHNOeJT-UudwsOQ==/lib/arm/libaudioenginedemo.so (SLESAudioEngine::release(TEMsg*)+486)
11-05 15:17:59.130 V/AudioFlinger( 1002): 5609 died, releasing its sessions
最佳答案
将 OpenSL 代码移至单独的线程后遇到同样的问题。幸运的是,Android OS sources给出了一个快速的答案:
static void proxy_cleanup(const void* id, void* obj, void* cleanupCookie)
{
android_atomic_dec(&gNumProxyRefs);
JNIEnv* env = javavm_to_jnienv((JavaVM*)cleanupCookie);
env->DeleteGlobalRef((jobject)obj);
}
长话短说,OpenSLES 引擎现在由 Java 对象支持,因此它需要有效的 JavaVM 引用才能运行。这基本上意味着,它应该从 JVM 附加线程创建(不确定破坏,但我猜 cleanupCookie
是出于某种原因传递的)。
关于android - 销毁引擎对象时如何避免android opensl es崩溃?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53150086/
当你有一个对象 OBJ1 包含一个关键部分 CS 和一个指向另一个对象 OBJ2 的指针时,我无法弄清楚什么是正确的关闭过程 假设您有两个函数 A 和 B。 A进入临界区,修改OBJ2中的数据后离开临
我有一个成员变量声明为 CComPtr m_spXMLDoc; XML 文档是这样创建的 CoCreateInstance(CLSID_DOMDocument, NULL, CLSCTX_INPROC
在我的工作平台中,我遇到了 session_destroy 问题 function logout() { $_SESSION['id'] = ''; session_destroy(); } 在这
如何使用 destroy 删除 jScrollPane。请您给出以下代码的简单示例: $(document).ready(function() { $(".div1").jScrollPane
这是我在这里发表的第一篇文章,但我想对社区表示感谢,因为通过来到这里并在已经得到解答的问题中找到解决方案,我已经无数次找到了问题的解决方案。 话虽这么说,我想进入正题。我正在 Code Gear 的
我在导航 View 中工作。在此导航 View 中,您可以偶然发现个人资料页面。在此个人资料页面中,您可以看到与当前个人资料相关的其他个人资料(基本上是数据 View 中显示的图片)。您可以通过点击这
我想销毁项目中的 session ,这样当我单击“注销”时,它会转到页面“KillSession.jsp”,在该文件中我编写了“session.invalidate();”然后我将用户重定向到登录页面
我有关于 Thread 的 2 问题,我只是想澄清一些事情。使用以下代码: public class MyThread implements Runnable { Boolean StopTh
我遇到了内存泄漏,代码类似于下面的代码(这是每个循环都有不同输入的模拟)。 问题 对象 Object_XXX 非常复杂,它与数据库以及其他填充了数据库数据的对象有连接。 for(int i=0
当我在 Python 中启动一个类时,我给它一些值。然后我调用类中执行某些操作的方法。这是一个片段: class TestClass(): def __init__(self):
我想删除所有 div、类、属性和几乎所有 CKEDITOR 添加到 DOM 的内容。例如调用 jquery tabs("destroy");将删除所有由 jQuery 选项卡添加的 div。我怎样才能
我想清除析构函数中的一个映射,但我不知道它是否为空。如果我按如下方式清除它可以吗? for(std::map::iterator it = m_map.begin(); it != m_map.end
我正在尝试克隆 TikTok 应用。对于主屏幕,我制作了一个 VerticalViewPager(自定义 View 分页器),其中包含“点赞”按钮、标题和评论。我正在从 Firebase 检索视频。
我正在制作自己的游戏。目标之一是在世界中拥有尽可能多的物体。在这个游戏中,需要在一些不可预测的时间段内创建许多对象(比如武器开火会创建一个对象),一旦该弹丸击中某物,该对象也需要被摧毁(也许它击中的东
有没有办法在 JavaScript 中破坏 HTML5 WebWorker? 这是我的情况:我有一个 Web 应用程序生成相当数量的 WebWorker(在 16 到 32 之间的任何地方)来优化一些
如何销毁 php 中的 session ? 事情是当用户点击注销按钮时, session 将结束,他将被重定向到 index.php 这是我的代码 客户.php 这是来自用户想要再次登录的 ind
关于 GtkBuilder 的问题。 当我们取消引用构建器指针时,它是否会破坏构建器创建的所有屏幕/小部件? if( builder_ptr ) g_object_unref(G_OBJECT
有没有办法销毁 WebView 实例?如果页面加载,并说视频开始播放,我希望能够,当我隐藏 WebView 时,基本上可以销毁它,或者至少重置它。 我知道我可以听 visibleProperty 并执
我有一组可拖动的元素。如何删除可拖动功能? $('.draggable').draggable('disable') 在我的情况下不是一个选项 $('.draggable').draggable('d
下面的代码会抛出一个 EZDecompressionError 消息 'Invalid ZStream operation' 每当行 Reader.Free 被执行。有人可以告诉我这段代码有什么问题吗
我是一名优秀的程序员,十分优秀!