java.lang.IllegalStateException:更改包名后无法执行活动错误的方法

时间:2013-05-29 20:41:29

标签: java android

所以我开发了一个应用程序,希望将其上传到Play商店,但是当它说我必须更改与com.example.app_name不同的包名时我改变了它。 但现在我收到了一个错误:

    05-29 22:35:15.599: E/AndroidRuntime(2196): java.lang.IllegalStateException: Could not execute method of the activity
05-29 22:35:15.599: E/AndroidRuntime(2196):     at android.view.View$1.onClick(View.java:3039)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at android.view.View.performClick(View.java:3480)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at android.view.View$PerformClick.run(View.java:13983)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at android.os.Handler.handleCallback(Handler.java:605)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at android.os.Handler.dispatchMessage(Handler.java:92)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at android.os.Looper.loop(Looper.java:137)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at android.app.ActivityThread.main(ActivityThread.java:4340)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at java.lang.reflect.Method.invokeNative(Native Method)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at java.lang.reflect.Method.invoke(Method.java:511)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at dalvik.system.NativeStart.main(Native Method)
05-29 22:35:15.599: E/AndroidRuntime(2196): Caused by: java.lang.reflect.InvocationTargetException
05-29 22:35:15.599: E/AndroidRuntime(2196):     at java.lang.reflect.Method.invokeNative(Native Method)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at java.lang.reflect.Method.invoke(Method.java:511)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at android.view.View$1.onClick(View.java:3034)
05-29 22:35:15.599: E/AndroidRuntime(2196):     ... 11 more
05-29 22:35:15.599: E/AndroidRuntime(2196): Caused by: java.lang.NullPointerException
05-29 22:35:15.599: E/AndroidRuntime(2196):     at com.gip.icomplain.Home.getGPSLocation(Home.java:209)
05-29 22:35:15.599: E/AndroidRuntime(2196):     at com.gip.icomplain.Home.send(Home.java:130)
05-29 22:35:15.599: E/AndroidRuntime(2196):     ... 14 more

这是我的代码:

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        this.setContentView(R.layout.activity_home);

        LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
        imv = (ImageView) findViewById(R.id.imvFoto);
        onderwerp = (TextView) findViewById(R.id.txtSubject);
        commentaar = (TextView) findViewById(R.id.txtComment);
        if (!locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)){
            showGPSDisabledAlertToUser();
        }
    }
    public void getGPSLocation() {
        if (!locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)){
            showGPSDisabledAlertToUser();
        }
        LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
        locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, MINIMUM_TIME_BETWEEN_UPDATES, MINIMUM_DISTANCE_CHANGE_FOR_UPDATES, new MyLocationListener());
        currentLocation = locationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER);

        if (currentLocation != null) {
            longitude = currentLocation.getLongitude();
            latitude = currentLocation.getLatitude();
        }
        EXTRA_TEXT = "http://maps.google.com/maps?q=" + latitude + "," + longitude;
    }
}

请帮助,这非常重要!!!!

2 个答案:

答案 0 :(得分:1)

您将locationManager作为类成员,但在onCreate中重新声明它。这样你就可以隐藏memeber类,它永远不会被初始化。

然后在getGpsLocation()中使用它:

public void getGPSLocation() {
        if (!locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)){
            showGPSDisabledAlertToUser();
        }

从onCreate

中删除LocationManager
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        this.setContentView(R.layout.activity_home);

        locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);

答案 1 :(得分:0)

您的getGPSLocationlocationManager处获得NullPointerException:

if (!locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)){
    showGPSDisabledAlertToUser();
}

您应该在locationManagerLocationManager中删除onCreate的重新声明(删除类型getGPSLocation):

@Override
public void onCreate(Bundle savedInstanceState) {
...
    locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
// Instead of: 
// LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
...
}

public void getGPSLocation() {
...
    locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
// Instead of: 
// LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
...
}

顺便说一句,你还应该在每个

之前检查locationmanager的空值

if (!locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)){