- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我需要更改android native jni 中的文件名(/system/etc/asound.conf)。我可以通过运行 shell cmd 在串行端口中执行此操作:
mount -o remount rw /system
busybox mv /system/etc/asound.conf /system/etc/asoundback.conf
mount -o remount r /system
首先,我通过调用 Runtime.getRuntiem(String) 在 java 中运行上面的 shell 脚本。 Ihis 将导致所有 android 系统服务重新加载。所以我没有这样做。
我通过像这样调用 system() 在 jni 中运行 shell 脚本:
android_media_AudioSystem_changeFileName(JNIEnv *env, jobject thiz, jstring from, jstring to)
{
const jchar* c_from = env->GetStringCritical(from, 0);
String8 c_from8;
if (from) {
c_from8 = String8(c_from, env->GetStringLength(from));
env->ReleaseStringCritical(from, c_from);
}
const jchar* c_to = env->GetStringCritical(to, 0);
String8 c_to8;
if (to) {
c_to8 = String8(c_to, env->GetStringLength(to));
env->ReleaseStringCritical(to, c_to);
}
LOGV("*********** android_media_AudioSystem_changeFileName from: %s ,to: %s" ,c_from8 ,c_to8);
char buff[4096];
sprintf(buff ,"mount -o remount rw /system;busybox mv %s %s;mount -o remount r /system" ,c_from8 ,c_to8);
if(system(buff) == -1) return -1;
return 0;
}
它不起作用。日志是:
[ 197.520000] mclkdiv = 2, bitclkdiv = 12
D/ALSAModule( 1160): open called for devices 00000002 in mode 0...
E/ALSALib ( 1160): external/alsa-lib/src/pcm/pcm.c:2203:(snd_pcm_open_noupdate) Unknown PCM AndroidPlayback_Speaker_normal
E/ALSALib ( 1160): external/alsa-lib/src/pcm/pcm.c:2203:(snd_pcm_open_noupdate) Unknown PCM AndroidPlayback_Speaker
E/ALSALib ( 1160): external/alsa-lib/src/pcm/pcm.c:2203:(snd_pcm_open_noupdate) Unknown PCM AndroidPlayback
I/ALSAModule( 1160): Initialized ALSA PLAYBACK device defaul
D/SoundSettings( 2041): ******* audio channel: codec
D/SoundSettings( 2041): ******* before asound-----> asoundback
I/AudioSystem( 2041): *********** android_media_AudioSystem_changeFileName
F/libc ( 2041): Fatal signal 11 (SIGSEGV) at 0xdeadbaad (code=1)
I/DEBUG ( 1155): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
I/DEBUG ( 1155): Build fingerprint: 'android:4.0.3/IML74K/eng.android.20120717.210618:eng/test-keys'
I/DEBUG ( 1155): pid: 2041, tid: 2041 >>> com.android.settings <<<
I/DEBUG ( 1155): signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr deadbaadI/DEBUG ( 1155): r0 deadbaad r1 00000001 r2 40000000 r3 00000000
I/DEBUG ( 1155): r4 00000000 r5 00000027 r6 62100021 r7 411afa18
I/DEBUG ( 1155): r8 be9b8644 r9 be9b864c 10 4786445b fp be9b8684
I/DEBUG ( 1155): ip ffffffff sp be9b8618 lr 40068f01 pc 40065660 cpsr 60000030
I/DEBUG ( 1155): #00 pc 00017660 /system/lib/libc.so
I/DEBUG ( 1155): #01 pc 0006f9de /system/lib/libandroid_runtime.so
I/DEBUG ( 1155): #02 pc 0001ebf0 /system/lib/libdvm.so (dvmPlatformInvoke)
I/DEBUG ( 1155): #03 pc 00058c38 /system/lib/libdvm.so (_Z16dvmCallJNIMethodPKjP6JValuePK6MethodP6Thread)
I/DEBUG ( 1155):
I/DEBUG ( 1155): code around pc:
I/DEBUG ( 1155): 40065640 4623b15c 2c006824 e026d1fb b12368db \.#F$h.,..&..h#.
I/DEBUG ( 1155): 40065650 21014a17 6011447a 48124798 24002527 .J.!zD.`.G.H'%.$
I/DEBUG ( 1155): 40065660 f7f47005 2106ef70 effef7f5 460aa901 .p..p..!.......F
I/DEBUG ( 1155): 40065670 f04f2006 94015380 94029303 ebc8f7f5 . O..S..........
I/DEBUG ( 1155): 40065680 4622a905 f7f52002 f7f4ebd2 2106ef5c .."F. ......\..!
I/DEBUG ( 1155):
I/DEBUG ( 1155): code around lr:
I/DEBUG ( 1155): 40068ee0 41f0e92d 46804c0c 447c2600 68a56824 -..A.L.F.&|D$h.h
I/DEBUG ( 1155): 40068ef0 e0076867 300cf9b5 dd022b00 47c04628 gh.....0.+..(F.G
I/DEBUG ( 1155): 40068f00 35544306 37fff117 6824d5f4 d1ee2c00 .CT5...7..$h.,..
I/DEBUG ( 1155): 40068f10 e8bd4630 bf0081f0 000285fa 41f0e92d 0F..........-..A
I/DEBUG ( 1155): 40068f20 fb01b086 9004f602 461f4815 4615460c .........H.F.F.F
I/DEBUG ( 1155):
I/DEBUG ( 1155): memory map around addr deadbaad:
有人可以帮助我吗?非常感谢!!!
最佳答案
我不是跟踪日志方面的专家,但据我所知,你有:
1. Fatal signal 11 (SIGSEGV) at 0xdeadbaad (code=1)
这意味着内存损坏,deadbaad 意味着内存损坏..
2. I/DEBUG ( 1155): signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr deadbaadI/DEBUG ( 1155): r0 deadbaad r1 00000001 r2 40000000 r3 00000000
这意味着注册表为空或 0..
我无能为力,因为我不知道你在做什么,但我猜你在某处读错了......
关于java - 在 android jni 中执行 shell 时出现以下错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11537194/
这个问题在这里已经有了答案: standalone parentheses in javascript [duplicate] (5 个答案) 关闭 8 年前。 我在学习JavaScript,有时会
我是mysql新手,我必须减少以下更新查询的执行时间 UPDATE temp_countcalculations, ( SELECT count(*) as insuffcounts,CRP_
def escape_html(s): for (i, o) in (("&","&"),(">", ">"),(" "变成 ">"等。 关于python - 以下 for 循环
if (read(read(cin, data1), data2)) 问题是C++ Primer 5th Edition 的练习。 read 函数定义如下: std::istream &read(st
我想创建两个宏。其中一个将扩展到函数原型(prototype)和函数内容,另一个将扩展到仅函数原型(prototype)。我正在考虑创建以下内容: #ifdef SOME_CONDITION #def
我正在使用 jongo API - org.jongo.MongoCollection 是类。 我有对象 ID 列表并转换为与 ObjectId[] 相同并尝试按如下方式查询 collection.f
有人可以解释以下正则表达式匹配什么吗? ^.*$ 谢谢! 最佳答案 或者整个字符串或者整行,取决于是否multiline mode被使用。 关于java - 以下 ^.*$ 正则表达式匹配什么?,我们
#include void main() { int a,b,c; for(b = c = 10; a = "- FIGURE?, UMKC,XYZHello Folks,TFy!QJ
我的代码段中的以下代码行被 Sonar 检测为问题。 代码段: final int Pending=1; Sonar 问题: Name 'Pending' must matc
Print name of all activities with neither maximum nor minimum number of participants 我尝试了以下查询,但出现错误:
这个问题在这里已经有了答案: What is this practice called in JavaScript? (7 个回答) 关闭8年前。 (function() { //do stuff
根据任务,我们必须通过 foldr 实现 foldl。通过比较函数签名和 foldl 实现,我得到了以下解决方案: myFoldl :: (a -> b -> a) -> a -> [b] -> a
这个问题在这里已经有了答案: Export an es6 default class inline with definition or at end of file? (1 个回答) 关闭 2 年
据我了解,以下是相同的: Person p{}; // Case 1 Person p = {}; // Case 1.5 我注意到 Person p = Person{}; // Case 2 产生
below i have given a javascript code picture `` can any one help me in this code. what do this code.
我想在标题和正文上搜索全文,并在答案计数上进行过滤。 我阅读了elasticsearch documentation for combining filters并构建了此查询。 "query": {
它是流动的 C 代码中的内存泄漏吗? #include int *a; int main() { a = malloc(sizeof(int)*10); return
这两个声明有什么区别: char (*ptr)[N]; 对比 char ptr[][N]; 谢谢。 最佳答案 (1)声明 char (*ptr)[N]; ptr 是指向大小为 N 的字符数组的指针 下
data II = I Int Int deriving (Show) instance II Show where show I a b = show (a+b) showt.hs:3:2: s
我从 clojuredoc 中阅读了关于 condp 的文档。在文档中我找到了以下代码: (condp 一些 [1 2 3 4] #{0 6 7} :>> 公司 #{4 5 9} :>> 十二月 #{
我是一名优秀的程序员,十分优秀!