在 targetSdkVersion 8 上运行 AsyncTask 时 Android 崩溃
Posted
技术标签:
【中文标题】在 targetSdkVersion 8 上运行 AsyncTask 时 Android 崩溃【英文标题】:Android Crash while running AsyncTask on targetSdkVersion 8 【发布时间】:2012-08-14 19:26:15 【问题描述】:当我设置 android:targetSdkVersion="8"
时,我的应用程序崩溃了,但是当我将其设置为 android:targetSdkVersion="11"
时,一切正常。请看logcat,我真的不知道我的代码有什么问题。看起来任何使用低于 11 的 SDK 的设备都会遇到这个问题。我的 min sdk 是 7。如果我继续交付我的应用程序,我可能会遇到很多麻烦。
public class SingleMenuItemActivity extends Activity
// XML node keys
static final String KEY_TITLE = "title";
static final String KEY_ARTIST = "artist";
static final String KEY_THUMB_URL = "thumb_url";
private ProgressDialog pDialog;
String title;
String artist;
String image_url;
ImageView view;
Intent intent;
Context context;
ShareActionProvider mShareActionProvider;
@Override
public void onCreate(Bundle savedInstanceState)
super.onCreate(savedInstanceState);
setContentView(R.layout.single_list_item);
new loadSingleView().execute();
view = (ImageView) findViewById(R.id.single_image);
public class loadSingleView extends AsyncTask<String, String, String>
@Override
protected void onPreExecute()
super.onPreExecute();
pDialog = new ProgressDialog(
SingleMenuItemActivity.this);
pDialog.setMessage("Connecting to Server ...");
pDialog.setIndeterminate(false);
pDialog.setCancelable(false);
pDialog.show();
@Override
protected String doInBackground(String... args)
// updating UI from Background Thread
Intent in = getIntent();
image_url = in.getStringExtra(KEY_THUMB_URL);
title = in.getStringExtra(KEY_TITLE);
artist = in.getStringExtra(KEY_ARTIST);
return null;
@Override
protected void onPostExecute(String args)
// dismiss the dialog after getting all products
ImageLoader imgLoader = new ImageLoader(getApplicationContext());
imgLoader.DisplayImage(image_url, view);
TextView lblName = (TextView) findViewById(R.id.name_title);
TextView lblCost = (TextView) findViewById(R.id.name_artist);
lblName.setText(title);
lblCost.setText(artist);
ActionBar ab = getActionBar();
ab.setTitle(title);
pDialog.dismiss();
Logcat:
08-19 02:19:03.351: E/AndroidRuntime(22761): FATAL EXCEPTION: main
08-19 02:19:03.351: E/AndroidRuntime(22761): java.lang.NullPointerException
08-19 02:19:03.351: E/AndroidRuntime(22761): at com.example.androidhive.SingleMenuItemActivity$loadSingleView.onPostExecute(SingleMenuItemActivity.java:88)
08-19 02:19:03.351: E/AndroidRuntime(22761): at com.example.androidhive.SingleMenuItemActivity$loadSingleView.onPostExecute(SingleMenuItemActivity.java:1)
08-19 02:19:03.351: E/AndroidRuntime(22761): at android.os.AsyncTask.finish(AsyncTask.java:602)
08-19 02:19:03.351: E/AndroidRuntime(22761): at android.os.AsyncTask.access$600(AsyncTask.java:156)
08-19 02:19:03.351: E/AndroidRuntime(22761): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:615)
08-19 02:19:03.351: E/AndroidRuntime(22761): at android.os.Handler.dispatchMessage(Handler.java:99)
08-19 02:19:03.351: E/AndroidRuntime(22761): at android.os.Looper.loop(Looper.java:137)
08-19 02:19:03.351: E/AndroidRuntime(22761): at android.app.ActivityThread.main(ActivityThread.java:4512)
08-19 02:19:03.351: E/AndroidRuntime(22761): at java.lang.reflect.Method.invokeNative(Native Method)
08-19 02:19:03.351: E/AndroidRuntime(22761): at java.lang.reflect.Method.invoke(Method.java:511)
08-19 02:19:03.351: E/AndroidRuntime(22761): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:982)
08-19 02:19:03.351: E/AndroidRuntime(22761): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749)
08-19 02:19:03.351: E/AndroidRuntime(22761): at dalvik.system.NativeStart.main(Native Method)
【问题讨论】:
知道了。感谢大家。我会接受最早的答复。 【参考方案1】:SDK 8 没有ActionBar
。您必须使用 ActionBarSherlock
库之类的东西来获得对 SDK ActionBar 支持。
【讨论】:
【参考方案2】:我认为这些代码行会导致 API 8 中的异常,
ActionBar ab = getActionBar();
ab.setTitle(title);
因为,ActionBar 是在 Android 3.0(API 级别 11) 中添加的。来自 Android 文档..
对于您的主题问题..
请看这两个 SO Questions..
ActionBar pre Honeycomb
How to implement the action bar in api levels less than 11?
【讨论】:
如果对您有帮助,请查看Support Library。【参考方案3】:不知道第 88 行是哪一行,问题可能就在这里:
ab.setTitle(title);
在 API 11 中添加了 ActionBar
http://developer.android.com/guide/topics/ui/actionbar.html
【讨论】:
以上是关于在 targetSdkVersion 8 上运行 AsyncTask 时 Android 崩溃的主要内容,如果未能解决你的问题,请参考以下文章
当我将 targetSdkVersion 29 更新为 targetSdkVersion 30 时出现问题
android:无法在 targetSdkVersion 更改时连接到相机服务
targetSdkVersion 23 通过 accountManager.getAccounts() 返回 0 长度数组