마스터Q&A 안드로이드는 안드로이드 개발자들의 질문과 답변을 위한 지식 커뮤니티 사이트입니다. 안드로이드펍에서 운영하고 있습니다. [사용법, 운영진]

단말기 강제 종료시 권환관련

0 추천
08-13 14:40:00.687: W/System.err(4022): java.io.SyncFailedException: fsync failed: EINVAL (Invalid argument)
08-13 14:40:00.687: W/System.err(4022): 	at java.io.FileDescriptor.sync(FileDescriptor.java:77)
08-13 14:40:00.687: W/System.err(4022): 	at java.io.FileOutputStream.flush(FileOutputStream.java:194)
08-13 14:40:00.697: W/System.err(4022): 	at 패키지명.AlarmReceiver.PowerOff(AlarmReceiver.java:99)
08-13 14:40:00.697: W/System.err(4022): 	at 패키지명.AlarmReceiver.onReceive(AlarmReceiver.java:61)
08-13 14:40:00.697: W/System.err(4022): 	at android.app.ActivityThread.handleReceiver(ActivityThread.java:2376)
08-13 14:40:00.697: W/System.err(4022): 	at android.app.ActivityThread.access$1500(ActivityThread.java:141)
08-13 14:40:00.697: W/System.err(4022): 	at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1310)
08-13 14:40:00.697: W/System.err(4022): 	at android.os.Handler.dispatchMessage(Handler.java:99)
08-13 14:40:00.707: W/System.err(4022): 	at android.os.Looper.loop(Looper.java:137)
08-13 14:40:00.707: W/System.err(4022): 	at android.app.ActivityThread.main(ActivityThread.java:5041)
08-13 14:40:00.707: W/System.err(4022): 	at java.lang.reflect.Method.invokeNative(Native Method)
08-13 14:40:00.707: W/System.err(4022): 	at java.lang.reflect.Method.invoke(Method.java:511)
08-13 14:40:00.707: W/System.err(4022): 	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:816)
08-13 14:40:00.707: W/System.err(4022): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:582)
08-13 14:40:00.707: W/System.err(4022): 	at dalvik.system.NativeStart.main(Native Method)
08-13 14:40:00.717: W/System.err(4022): Caused by: libcore.io.ErrnoException: fsync failed: EINVAL (Invalid argument)
08-13 14:40:00.717: W/System.err(4022): 	at libcore.io.Posix.fsync(Native Method)
08-13 14:40:00.717: W/System.err(4022): 	at libcore.io.BlockGuardOs.fsync(BlockGuardOs.java:97)
08-13 14:40:00.717: W/System.err(4022): 	at java.io.FileDescriptor.sync(FileDescriptor.java:74)
08-13 14:40:00.717: W/System.err(4022): 	... 14 more

 

스마트폰이 아닌 Android 기반 단말기를 강제 전원Off 시키는 루틴을 적용하였습니다.

스마트폰은 루트 권환이 필요하여 적용이 안되지만

해당 단말기는 위와같은 에러를 품어내며 전원 Off가 되네요.

 

루트권한은 안되있는걸로 아는데, 이런경우 어떠한 상태라고 봐야될까요?

 

강제종료는 아래와 같이 정의하였습니다.

private void PowerOff(){
		try {
			// Root 권한 필요
			Process p = Runtime.getRuntime().exec("su");
			OutputStream os = p.getOutputStream();
			os.write("reboot -p\n".getBytes());
			os.flush();
		} catch (Exception e) {e.printStackTrace();}
	}
	

 

개발자초심 (21,220 포인트) 님이 2015년 8월 13일 질문

답변 달기

· 글에 소스 코드 보기 좋게 넣는 법
· 질문에 대해 추가적인 질문이나 의견이 있으면 답변이 아니라 댓글로 달아주시기 바랍니다.
표시할 이름 (옵션):
개인정보: 당신의 이메일은 이 알림을 보내는데만 사용됩니다.
스팸 차단 검사:
스팸 검사를 다시 받지 않으려면 로그인하거나 혹은 가입 하세요.
...