Eclipse Android应用程序操作栏不工作

Eclipse Android应用程序操作栏不工作,eclipse,android-actionbar,android,Eclipse,Android Actionbar,Android,所以我一直在开发一个应用程序 现在,当我将minSdkVersion从8更改为11时,操作栏工作正常,除了一个活动外,其他所有活动都正常。当我在allproducts活动中选择一个产品进行编辑时崩溃了,我相信这意味着问题出在editproductsactivity中,但我对android上的编程非常陌生,所以我迷路了。当我将minSdkVersion设置为8时,它可以工作,但由于某种原因,当我将其设置为11时,只有此活动停止工作。有人能帮我吗 编辑:我在logcat中得到的错误是 01-15 1

所以我一直在开发一个应用程序

现在,当我将minSdkVersion从8更改为11时,操作栏工作正常,除了一个活动外,其他所有活动都正常。当我在allproducts活动中选择一个产品进行编辑时崩溃了,我相信这意味着问题出在editproductsactivity中,但我对android上的编程非常陌生,所以我迷路了。当我将minSdkVersion设置为8时,它可以工作,但由于某种原因,当我将其设置为11时,只有此活动停止工作。有人能帮我吗

编辑:我在logcat中得到的错误是

01-15 13:16:14.314: W/dalvikvm(13431): threadid=1: thread exiting with uncaught exception (group=0x416e2d28)
01-15 13:16:14.317: E/AndroidRuntime(13431): FATAL EXCEPTION: main
01-15 13:16:14.317: E/AndroidRuntime(13431): Process: com.example.androidhive, PID: 13431
01-15 13:16:14.317: E/AndroidRuntime(13431): android.os.NetworkOnMainThreadException
01-15 13:16:14.317: E/AndroidRuntime(13431):    at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1145)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at libcore.io.IoBridge.connect(IoBridge.java:112)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:460)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at java.net.Socket.connect(Socket.java:833)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at com.example.androidhive.JSONParser.makeHttpRequest(JSONParser.java:62)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at com.example.androidhive.EditProductActivity$GetProductDetails$1.run(EditProductActivity.java:143)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at android.os.Handler.handleCallback(Handler.java:733)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at android.os.Handler.dispatchMessage(Handler.java:95)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at android.os.Looper.loop(Looper.java:137)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at android.app.ActivityThread.main(ActivityThread.java:5083)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at java.lang.reflect.Method.invokeNative(Native Method)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at java.lang.reflect.Method.invoke(Method.java:515)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
01-15 13:16:14.317: E/AndroidRuntime(13431):    at dalvik.system.NativeStart.main(Native Method)
提前谢谢大家,


Tyler Moskov

旧版本的android允许在主线程上运行与网络相关的任务,但他们改变了这一点,因为与网络相关的任务可能比阻止主线程花费更多的时间。因此,在较新的版本中,必须在不同的线程上运行这些任务,而不是在主线程(也称为UI线程)上运行


检查此页面以获取解决此问题的代码

尝试此操作。我将数据类型更改为JSONObject,如前所述,在与用户界面组件交互时使用onPostExecute。代码中的问题是从不同的线程doinBackground调用主线程runOnUIthread

class GetProductDetails extends AsyncTask<String, JSONObject, JSONObject> {

    /**
     * Before starting background thread Show Progress Dialog
     * */
    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        pDialog = new ProgressDialog(EditProductActivity.this);
        pDialog.setMessage("Loading product details. Please wait...");
        pDialog.setIndeterminate(false);
        pDialog.setCancelable(true);
        pDialog.show();
    }

    /**
     * Getting product details in background thread
     * */
    protected JSONObject doInBackground(String... params) {

                // Check for success tag
                int success;
                try {
                    // Building Parameters
                    List<NameValuePair> params = new ArrayList<NameValuePair>();
                    params.add(new BasicNameValuePair("pid", pid));

                    // getting product details by making HTTP request
                    // Note that product details url will use GET request
                    JSONObject json = jsonParser.makeHttpRequest(
                            url_product_detials, "GET", params);

                    // check your log for json response
                    Log.d("Single Product Details", json.toString());

                    // json success tag
                    success = json.getInt(TAG_SUCCESS);
                    if (success == 1) {
                        // successfully received product details
                        JSONArray productObj = json
                                .getJSONArray(TAG_PRODUCT); // JSON Array

                        // get first product object from JSON Array
                        JSONObject product = productObj.getJSONObject(0);


                    }else{
                        // product with pid not found
                    }
                } catch (JSONException e) {
                    e.printStackTrace();
                }
            }
        });

        return null;
    }


    /**
     * After completing background task Dismiss the progress dialog
     * **/
    protected void onPostExecute(JSONObject result) {
        // dismiss the dialog once got all details
        pDialog.dismiss();
        JSONObject product = result;

        setContentView(R.layout.edit_product);

        // product with this pid found
        // Edit Text
        txtName = (EditText) findViewById(R.id.inputName);
        txtPrice = (EditText) findViewById(R.id.inputPrice);
        txtDesc = (EditText) findViewById(R.id.inputDesc);

        // display product data in EditText
        txtName.setText(product.getString(TAG_NAME));
        txtPrice.setText(product.getString(TAG_PRICE));
        txtDesc.setText(product.getString(TAG_DESCRIPTION));
    }
}

NetworkOnMainThreadException发生在您在asyctask的doInBackground之外的主线程中与服务器进行通信时,请查找samething@vipulmittal感谢您的帮助。因此,从OnCreate获取涉及网络连接的代码,并将其放入DoInBackground?不管怎样,我看到它是JSONParser JSONParser=new JSONParser;在主线程中,所以我需要将其移出主线程,并将其放入DoInBackground?这样就固定了它。谢谢你的帮助。不管怎样,把它放在doinbackground中也没用,我只是忘了把它改回11而不是8;把它放在DoInBackground里是行不通的。还有什么建议吗?因为我完全迷路了…我不知道你是如何努力实现的。你能把代码贴在这里吗?注意:doInBackground在后台运行,onPostExecute在主线程上运行。因此,如果您想在UI组件中填充结果,请使用onPostExecute,因为只有主线程可以接触诸如TextView、ListView等UI组件。它表示已经声明了params,并将标记放在List params=new ArrayList旁边;以及txtName.setTextproduct.getStringTAG_NAME的未处理异常类型JSONException;对不起,我在记事本里编辑的。在此处更改变量名->受保护的JSONObject doInBackgroundString。。。一串用try-catch->try{JSONObject product=result;…..txtDesc.setTextproduct…}好的,但现在出现了一个新错误:01-15 17:11:49.412:E/AndroidRuntime25485:java.lang.NullPointerException。它看起来像是在onpost可执行文件中。所以这个名字是空的?是的,它肯定是空的。我不知道为什么。好了,开始工作了。非常感谢你的帮助。