当我尝试使用以下代码在程序中设置评分栏的评分(从远程数据库检索)时,我收到如下所示的错误...
09-18 19:57:16.858: D/dalvikvm(1411): GC_CONCURRENT freed 43K, 7% free 2775K/2960K, paused 16ms+21ms, total 134ms
09-18 19:57:17.057: I/Choreographer(1411): Skipped 40 frames! The application may be doing too much work on its main thread.
09-18 19:57:17.077: D/gralloc_goldfish(1411): Emulator without GPU emulation detected.
09-18 19:57:21.146: D/dalvikvm(1411): GC_CONCURRENT freed 20K, 5% free 3211K/3376K, paused 73ms+6ms, total 260ms
09-18 19:57:21.737: D/dalvikvm(1411): GC_FOR_ALLOC freed 361K, 15% free 3032K/3540K, paused 167ms, total 196ms
09-18 19:57:21.776: I/dalvikvm-heap(1411): Grow heap (frag case) to 3.940MB for 883132-byte allocation
09-18 19:57:21.976: D/dalvikvm(1411): GC_FOR_ALLOC freed 1K, 12% free 3894K/4404K, paused 204ms, total 206ms
09-18 19:57:22.146: D/dalvikvm(1411): GC_CONCURRENT freed <1K, 12% free 3893K/4404K, paused 8ms+29ms, total 170ms
09-18 19:57:22.146: D/dalvikvm(1411): WAIT_FOR_CONCURRENT_GC blocked 94ms
09-18 19:57:22.156: I/dalvikvm-heap(1411): Grow heap (frag case) to 4.313MB for 392920-byte allocation
09-18 19:57:22.316: D/dalvikvm(1411): GC_FOR_ALLOC freed <1K, 11% free 4277K/4788K, paused 154ms, total 154ms
09-18 19:57:25.196: E/demo(1411): {"success":1,"product":[{"site_name":"Lynda","rating":"3.00"}]}
09-18 19:57:25.297: D/Rating(1411): {"product":[{"site_name":"Lynda","rating":"3.00"}],"success":1}
09-18 19:57:25.306: D/AndroidRuntime(1411): Shutting down VM
09-18 19:57:25.306: W/dalvikvm(1411): threadid=1: thread exiting with uncaught exception (group=0x40a71930)
09-18 19:57:25.526: E/AndroidRuntime(1411): FATAL EXCEPTION: main
09-18 19:57:25.526: E/AndroidRuntime(1411): java.lang.NullPointerException
09-18 19:57:25.526: E/AndroidRuntime(1411): at com.khizer.myproject.online_tut$MyAdapter.getView(online_tut.java:106)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.widget.AbsListView.obtainView(AbsListView.java:2159)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.widget.ListView.measureHeightOfChildren(ListView.java:1246)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.widget.ListView.onMeasure(ListView.java:1158)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.View.measure(View.java:15518)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.widget.RelativeLayout.measureChild(RelativeLayout.java:666)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:477)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.View.measure(View.java:15518)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4825)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.View.measure(View.java:15518)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.widget.LinearLayout.measureVertical(LinearLayout.java:847)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.widget.LinearLayout.onMeasure(LinearLayout.java:588)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.View.measure(View.java:15518)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4825)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
09-18 19:57:25.526: E/AndroidRuntime(1411): at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:2176)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.View.measure(View.java:15518)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:1874)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1089)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1265)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:989)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4351)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.Choreographer.doCallbacks(Choreographer.java:562)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.Choreographer.doFrame(Choreographer.java:532)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.os.Handler.handleCallback(Handler.java:725)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.os.Handler.dispatchMessage(Handler.java:92)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.os.Looper.loop(Looper.java:137)
09-18 19:57:25.526: E/AndroidRuntime(1411): at android.app.ActivityThread.main(ActivityThread.java:5041)
09-18 19:57:25.526: E/AndroidRuntime(1411): at java.lang.reflect.Method.invokeNative(Native Method)
09-18 19:57:25.526: E/AndroidRuntime(1411): at java.lang.reflect.Method.invoke(Method.java:511)
09-18 19:57:25.526: E/AndroidRuntime(1411): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
09-18 19:57:25.526: E/AndroidRuntime(1411): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
09-18 19:57:25.526: E/AndroidRuntime(1411): at dalvik.system.NativeStart.main(Native Method)
09-18 19:57:28.536: I/Process(1411): Sending signal. PID: 1411 SIG: 9
我正在使用列表视图来显示提供在线教程的站点的名称以及评分。日志提到错误在第 106 行,第 106 行是此行之后的行
String f=new GetRating().execute("Lynda").get();
即(下面的行是第106行)
rbs.setRating(Float.parseFloat(f));
这是完整的代码...
package com.khizer.myproject;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ExecutionException;
import org.apache.http.NameValuePair;
import org.apache.http.message.BasicNameValuePair;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import android.app.ListActivity;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.RatingBar;
import android.widget.TextView;
public class online_tut extends ListActivity {
// ProgressDialog pDialog;
final JSONParser jsonParser = new JSONParser();
final String url_get_rating = "http://192.168.1.4/webguide/getrating.php";
final String TAG_SUCCESS = "success";
final String TAG_RATE = "rating";
String TAG_SITE="site_name";
String TAG_PRODUCT = "product";
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.online_tut);
setListAdapter(new MyAdapter
(this, android.R.layout.simple_list_item_1,R.id.ot_custlist_textview1,
getResources().getStringArray(R.array.online_tutorials_menu)));
}
private class MyAdapter extends ArrayAdapter<String>
{
public MyAdapter(Context context,int resource,
int textViewResourceId,String[] strings){
super(context,resource,textViewResourceId,strings);
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
LayoutInflater infalter= (LayoutInflater) getSystemService(LAYOUT_INFLATER_SERVICE);
View row=infalter.inflate(R.layout.online_tut_menu, parent, false);
final String[] items= getResources().getStringArray(R.array.online_tutorials_menu);
RatingBar rbs=(RatingBar) findViewById(R.id.ratingbar_Small);
ImageView iv= (ImageView) row.findViewById(R.id.imageView1);
TextView tv=(TextView) row.findViewById(R.id.ot_info_head);
ImageView iv1=(ImageView) row.findViewById(R.id.image_info);
TextView tv1= (TextView) findViewById(R.id.rating_text);
tv.setText(items[position]);
iv1.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
Intent in=new Intent(online_tut.this,Info.class);
if(items[position].equals("Lynda"))
{
in.putExtra("name","Lynda");
}
else if(items[position].equals("My Bring Back"))
{
in.putExtra("name","My Bring Back");
}else if(items[position].equals("New Boston"))
{
in.putExtra("name","New Boston");
}else if(items[position].equals("NPTEL"))
{
in.putExtra("name","NPTEL");
}
startActivity(new Intent(in));
}
});
if(items[position].equals("Lynda"))
{
iv.setImageResource(R.drawable.lynda);
try {
String f=new GetRating().execute("Lynda").get();
rbs.setRating(Float.parseFloat(f));
} catch (InterruptedException e) {
Log.d("khizer","IEX");
e.printStackTrace();
} catch (ExecutionException e) {
Log.d("khzer","khzier");
e.printStackTrace();
}
}
else if(items[position].equals("My Bring Back"))
{
iv.setImageResource(R.drawable.grey);
try {
String f=new GetRating().execute("My Bring Back").get();
tv1.setText(f);
rbs.setRating(Float.parseFloat(f));
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
else if(items[position].equals("New Boston"))
{
iv.setImageResource(R.drawable.grey);
try {
String f=new GetRating().execute("New Boston").get();
tv1.setText(f);
rbs.setRating(Float.parseFloat(f));
} catch (InterruptedException e) {
Log.d("khizer","IEX");
e.printStackTrace();
} catch (ExecutionException e) {
Log.d("khzer","khzier");
e.printStackTrace();
}
}
else if(items[position].equals("NPTEL"))
{
iv.setImageResource(R.drawable.grey);
try {
String f=new GetRating().execute("NPTEL").get();
tv1.setText(f);
rbs.setRating(Float.parseFloat(f));
} catch (InterruptedException e) {
Log.d("khizer","IEX");
e.printStackTrace();
} catch (ExecutionException e) {
Log.d("khzer","khzier");
e.printStackTrace();
}
}
return row;
}
}
class GetRating extends AsyncTask<String,String,String>{
/* @Override
protected void onPreExecute() {
super.onPreExecute();
//pDialog = new ProgressDialog(Rating.this);
pDialog.setMessage("Populating list");
pDialog.setIndeterminate(false);
pDialog.setCancelable(true);
pDialog.show();
}*/
@Override
protected String doInBackground(String... arg) {
int success;
String f=null;
try {
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("site_name",arg[0]));
JSONObject json = jsonParser.makeHttpRequest(
url_get_rating, "GET", params);
// TAG_SITE=arg[0];
Log.d("Rating", json.toString());
success = json.getInt(TAG_SUCCESS);
if (success == 1) {
JSONArray productObj = json
.getJSONArray(TAG_PRODUCT);
JSONObject product = productObj.getJSONObject(0);
f=product.getString(TAG_RATE);
}
else{
Log.d("Rating","Site Not Found");
}
}catch (JSONException e) {
e.printStackTrace();
}
return f;
}
//protected void onPostExecute(String file_url) {
// cancel(true);
//}
}
}
以下是 xml 文件: 1) 对于列表视图...
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
xmlns:android="http://schemas.android.com/apk/res/android">
<TextView
android:id="@+id/ot_custlist_textview1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingTop="5dp"
android:text="@string/ot_head"
android:textAppearance="?android:attr/textAppearanceLarge"
android:textSize="25sp" />
<ListView
android:id="@android:id/list"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/ot_custlist_textview1"
android:clipChildren="true" >
</ListView>
</RelativeLayout>
2)列表项的xml ..
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="70dp"
android:orientation="horizontal" >
<ImageView
android:id="@+id/imageView1"
android:layout_width="70dp"
android:layout_height="70dp"
android:contentDescription="@string/logo"
android:src="@drawable/lynda" />
<include
android:layout_width="0dp"
android:layout_height="70dp"
android:layout_weight="1.75"
layout="@layout/star" />
<ImageView
android:id="@+id/image_info"
android:layout_width="70dp"
android:layout_height="70dp"
android:contentDescription="@string/ot_info_image"
android:paddingBottom="15dp"
android:paddingLeft="15dp"
android:paddingRight="15dp"
android:paddingTop="15dp"
android:src="@drawable/info" />
</LinearLayout>
使用的其他xml是...
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<TextView
android:id="@+id/ot_info_head"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:gravity="center|left"
android:paddingBottom="2dp"
android:paddingLeft="10dp"
android:paddingTop="10dp"
android:text="Large Text"
android:textAppearance="?android:attr/textAppearanceLarge"
android:textSize="23sp" />
<RatingBar
android:id="@+id/ratingbar_Small"
style="?android:attr/ratingBarStyleSmall"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/ot_info_head"
android:layout_marginLeft="10dp"
android:minHeight="14dp"
android:numStars="5"
android:paddingTop="4dp" />
<TextView
android:id="@+id/rating_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignTop="@+id/ratingbar_Small"
android:layout_toRightOf="@+id/ratingbar_Small"
android:paddingLeft="3dp"
android:paddingTop="2dp"
android:text="Small Text"
android:textAppearance="?android:attr/textAppearanceSmall" />
</RelativeLayout>