跨进程调用异常分析总结

本文详细探讨了Android中跨进程通信时可能出现的异常情况及其处理方式。具体分析了客户端和服务端在不同异常处理策略下的行为差异,并给出了具体的日志示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

http://blog.youkuaiyun.com/huangyabin001/article/details/42914771
12-07 20:01:19.931  7272  7272 E AndroidRuntime: FATAL EXCEPTION: main
12-07 20:01:19.931  7272  7272 E AndroidRuntime: Process: com.miui.whetstone, PID: 7272
12-07 20:01:19.931  7272  7272 E AndroidRuntime: java.lang.SecurityException: killPids only available to the system
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at android.os.Parcel.readException(Parcel.java:1683)
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at android.os.Parcel.readException(Parcel.java:1636)
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at android.app.ActivityManagerProxy.killPids(ActivityManagerNative.java:5140)
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.miui.whetstone.server.IActivityManagerWrapper.killPids()
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.miui.whetstone.wtstrategy.WtProcessStrategy.doTrimMiddle()
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.miui.whetstone.wtstrategy.WtProcessStrategy.dealProcessInBackground()
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.miui.whetstone.wtstrategy.WtProcessStrategy.onHandleBackGroundProcess()
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.miui.whetstone.process.WtProcessController.notifyHandleBackGroundProcess()
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.miui.whetstone.process.WtProcessController.dispatchDealBackgroundProcess()
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.miui.whetstone.process.WtProcessController.-wrap2()
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.miui.whetstone.process.WtProcessController$WtProcessHandler.handleMessage()
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at android.os.Handler.dispatchMessage(Handler.java:102)
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at android.os.Looper.loop(Looper.java:163)
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at android.app.ActivityThread.main(ActivityThread.java:6337)
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at java.lang.reflect.Method.invoke(Native Method)
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:880)
12-07 20:01:19.931  7272  7272 E AndroidRuntime: 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:770)
我们经常会进行跨进程通信,跨进程通信设计两个进进程,现记为client , server端
cient端发生异常:1.没有加catch处理,则异常会直接抛给client端,手机端会弹出XXX已经停止运行
                2.加了catch处理,异常被catch住,手机端不会弹出XXX已经停止运行  
server端发生异常:1.server端没有catch,则直接抛给client端,
                   1.1 如果clent端也没有catch,则client会弹出XXX已经停止运行
                   1.2 如果clent端catch,则client不会弹出XXX已经停止运行
                 2.server端catch,则不会抛给client端

注:如果是oneway调用,server端发生异常,不会抛到client端。服务端会打出如下log

01-18 15:06:51.070  8622  8641 W Binder  : Caught a RuntimeException from the binder stub implementation.
01-18 15:06:51.070  8622  8641 W Binder  : java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String java.lang.String.toString()' on a null object reference
01-18 15:06:51.070  8622  8641 W Binder  :     at com.miui.securityspace.service.SecondSpaceService$SpaceBinder.createUser(SecondSpaceService.java:82)
01-18 15:06:51.070  8622  8641 W Binder  :     at com.miui.securityspace.service.ISpaceService$Stub.onTransact(ISpaceService.java:48)
01-18 15:06:51.070  8622  8641 W Binder  :     at android.os.Binder.execTransact(Binder.java:453)
//官方网站:www.feiyuol.com //郁金香灬老师 //QQ 150330575 //个人网站:www.yjxsoft.com 跨进程调用CALL 跨进程调用带多个的参数CALL // myInject_dll.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include #include"RWA.h" //PVOID 跨进程分配内存(WORD nSize ); //1、获取进程句柄 //2、读写 分配内存 创建线程 //3、跨进程分配内存 void mycall() { PVOID p1=跨进程分配内存(1000); printf("分配的内存地址=%p\n",p1); printf("按回车键 释放内存\n"); getchar(); 跨进程释放内存(p1,1000); printf("已经 释放内存\n"); } LPTHREAD_START_ROUTINE a; BOOL 跨进程调用CALL(PVOID pcall地址,PVOID plst参数 ); //LoadLibraryA(dll名字指针) //MessageBeep(1) void Test远程调用MessageBeep() { 跨进程调用CALL(MessageBeep,(PVOID)0x12768); } //注入my022MFC.dll到目标进程 void Test3() { char szDllName[]="my022MFC.dll"; //全路径 // char szDllName[]="C:\\Users\\yjxsoft\\Documents\\visual studio 2010\\Projects\\my022\\Debug\\my022MFC.dll"; PVOID p1=跨进程分配内存(1000); printf("分配的内存地址=%p\n",p1); WN((DWORD)p1,szDllName,sizeof(szDllName));//WriteProcessMemory /*跨进程调用CALL(LoadLibraryA,(PVOID)szDllName);*/ 跨进程调用CALL(LoadLibraryA,(PVOID)p1); } void Test4() { // char szDllName[]="my022MFC.dll"; //全路径 char szDllName[]="E:\\1905\\代码\\my022-24\\Debug\\my022MFC.dll"; PVOID p1=跨进程分配内存(1000); printf("分配的内存地址=%p\n",p1); WN((DWORD)p1,szDllName,sizeof(szDllName));//WriteProcessMemory /*跨进程调用CALL(LoadLibraryA,(PVOID)szDllName);*/ 跨进程调用CALL(LoadLibraryA,(PVOID)p1); } int _tmain(int argc, _TCHAR* argv[]) { //mycall(); Test3(); Test4(); return 0; } //作业 //1、练习跨进程注入DLL //2、跨进程分配的内存内存 使用完后 用VirtualFreeEx释放掉 //3、进程句柄使用完后用CloseHandle释放句柄资源
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值