0

誰かが助けてくれるなら、それは素晴らしいことです。私は他の場所で提供されている解決策を見てきましたが、私の問題を解決していないようです。

私は DeviceAdminReceiver を使用しており、ボタンが押されたときにロック デバイスをテストしています。実際には機能しますが、アプリケーションを初めて実行すると、アクティビティがクラッシュします。(このクラッシュは、最初の実行時に 1 回だけ発生します)。

java.lang.RuntimeException: Unable to instantiate receiver c: java.lang.InstantiationException: can't instantiate class com.example.deviceadmin.MainActivity$myAdmin; no empty constructor

この問題を解決するために多くのことを試しました:

1) DeviceAdminReceiver のサブクラスにコンストラクターを追加する
2) コンストラクター内で Super を呼び出す。

これは私が提案した解決策ですが、うまくいきません。

ここに私のアプリの簡略化されたコードがあります:

public class MainActivity extends Activity {

protected static final int REQUEST_ENABLE = 0;
private static final String LOG = "adminClient";
private DevicePolicyManager mDPM;
private ComponentName mAdminName;

@Override
protected void onCreate(Bundle savedInstanceState) {
    Log.d(LOG, "onCreate");
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    mDPM = (DevicePolicyManager)getSystemService(Context.DEVICE_POLICY_SERVICE);
    mAdminName = new ComponentName(this, myAdmin.class);
    Log.d(LOG, "mAdminName = " + mAdminName.toString());

    Button deviceLock = (Button) findViewById(R.id.button1);

    deviceLock.setOnClickListener(new OnClickListener() {


        @Override
        public void onClick(View v) {
            // TODO Auto-generated method stub
            Log.d(LOG, "LockPhone clicked");
            lockPhone();
        }

    });

}





protected void lockPhone() {
       if (!mDPM.isAdminActive(mAdminName)) {

            Intent intent = new Intent(DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN);
            intent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN,
            mAdminName);
            intent.putExtra("force-locked", DeviceAdminInfo.USES_POLICY_FORCE_LOCK);        
            startActivityForResult(intent, REQUEST_ENABLE);
            } 
           else {   
            Log.d(LOG, "lockDown phone");
            mDPM.lockNow();
            }
}


class myAdmin extends DeviceAdminReceiver {

    public myAdmin(){
        super();

    }


}

}

ログ

08-16 14:46:06.383: E/AndroidRuntime(17963): FATAL EXCEPTION: main
08-16 14:46:06.383: E/AndroidRuntime(17963): java.lang.RuntimeException: Unable to instantiate receiver com.example.deviceadmin.MainActivity$myAdmin: java.lang.InstantiationException: can't instantiate class com.example.deviceadmin.MainActivity$myAdmin; no empty constructor
08-16 14:46:06.383: E/AndroidRuntime(17963):    at android.app.ActivityThread.handleReceiver(ActivityThread.java:2356)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at android.app.ActivityThread.access$1500(ActivityThread.java:140)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1309)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at android.os.Handler.dispatchMessage(Handler.java:99)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at android.os.Looper.loop(Looper.java:137)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at android.app.ActivityThread.main(ActivityThread.java:5047)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at java.lang.reflect.Method.invokeNative(Native Method)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at java.lang.reflect.Method.invoke(Method.java:525)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:821)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:588)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at dalvik.system.NativeStart.main(Native Method)
08-16 14:46:06.383: E/AndroidRuntime(17963): Caused by: java.lang.InstantiationException: can't instantiate class com.example.deviceadmin.MainActivity$myAdmin; no empty constructor
08-16 14:46:06.383: E/AndroidRuntime(17963):    at java.lang.Class.newInstanceImpl(Native Method)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at java.lang.Class.newInstance(Class.java:1130)
08-16 14:46:06.383: E/AndroidRuntime(17963):    at android.app.ActivityThread.handleReceiver(ActivityThread.java:2351)
08-16 14:46:06.383: E/AndroidRuntime(17963):    ... 10 more
4

1 に答える 1