这是 myDB 类 //请看一下 public Cursor getplaces() --- 我是对还是错?如果我想 setListAdapter,如何在主 Activity 类中编码。感谢您的帮助。
公共类 MyDB { 受保护的静态最终字符串 TAG = "TAG"; 私有最终上下文 mContext; 私有 SQLiteDatabase mDb; 私人 MyDBhelper mDbHelper; 公共MyDB(上下文上下文){ this.mContext = 上下文; mDbHelper = new MyDBhelper(mContext); } 公共 MyDB createDatabase() 抛出 SQLException { 尝试 { mDbHelper.createDataBase(); } 捕捉(IOException mIOException) { Log.e(TAG, mIOException.toString() + "UnableToCreateDatabase"); 抛出新错误(“UnableToCreateDatabase”); } 返回这个; } 公共 MyDB open() 抛出 SQLException { 尝试 { mDbHelper.openDataBase(); mDbHelper.close(); mDb = mDbHelper.getReadableDatabase(); } 捕获(SQLException mSQLException) { Log.e(TAG, mSQLException.toString()); 抛出 mSQLException; } 返回这个; } 公共游标 getplaces() { 光标 c = mDb.query(Constants.DATABASE_NAME, null, null, null, null, null, null); 返回 c; } 公共无效关闭() { mDbHelper.close(); } }
ListplaceActivity 类
公共 ListplaceActivity 扩展 ListActivity { 私有静态 MyDB mDbHelper; String[] from = new String[] { 常量.TITLE_NAME }; int[] to = new int[] {R.id.place_title}; @覆盖 公共无效 onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); mDbHelper = new MyDB(this); 光标 c = mDbHelper.getplaces(); setListAdapter(新的 SimpleCursorAdapter(这个, R.layout.list_place, c, 从到)); 最终列表视图 lv = getListView(); lv.setOnItemClickListener(new OnItemClickListener() { public void onItemClick(AdapterView parent, View view,int position, long id) { 意图 newActivity = new Intent(view.getContext(), Place.class); 开始活动(新活动); } }); } }
在我单击转到 ListplacesActivity 页面后,在 LogCat 中显示如下,它发生“意外停止”并且没有显示任何列表:
05-30 21:49:21.543:信息/进程(17605):发送信号。PID:17605 SIG:9 05-30 21:49:21.583: INFO/ActivityManager(59): 进程 com.ctg (pid 17605) 已经死亡。 05-30 21:49:21.593: INFO/WindowManager(59): WIN DEATH: Window{44de90a0 com.ctg/com.ctg.CTG paused=false} 05-30 21:49:21.674:INFO/ActivityManager(59):为活动 com.ctg/.CTG 启动 proc com.ctg:pid=27207 uid=10028 gids={} 05-30 21:49:21.733: 错误/gralloc(59): [注销] 句柄 0x5fe9d8 仍被锁定(状态 = 40000001) 05-30 21:49:22.103: DEBUG/ddm-heap(27207): 得到功能列表请求 05-30 21:49:22.265:INFO/UsageStats(59):com.ctg 意外恢复,而 com.ctg 已经恢复 05-30 21:49:23.084:调试/dalvikvm(27207):GC 在 216 毫秒内释放了 801 个对象/58520 个字节 05-30 21:49:23.433:调试/dalvikvm(27207):GC 在 129 毫秒内释放了 93 个对象/3632 个字节 05-30 21:49:23.623: WARN/PhoneWindow(27207): 以前聚焦的视图在保存过程中报告了 id 16908298,但在恢复过程中找不到。 05-30 21:49:23.843: WARN/InputManagerService(59): 收到 RemoteException 向 pid 17605 uid 10028 发送 setActive(false) 通知 05-30 21:49:24.103:INFO/ActivityManager(59):显示的活动 com.ctg/.CTG:2489 毫秒(总共 33589 毫秒) 05-30 21:49:29.013: INFO/ActivityManager(59): 开始活动: Intent { cmp=com.ctg/.AttractionsListActivity } 05-30 21:49:29.085:调试/AndroidRuntime(27207):关闭 VM 05-30 21:49:29.085: WARN/dalvikvm(27207): threadid=3: 线程以未捕获的异常退出 (group=0x4001b188) 05-30 21:49:29.094:错误/AndroidRuntime(27207):未捕获的处理程序:线程主因未捕获的异常而退出 05-30 21:49:29.114: 错误/AndroidRuntime(27207): java.lang.RuntimeException: 无法启动活动 ComponentInfo{com.ctg/com.ctg.AttractionsListActivity}: java.lang.NullPointerException 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2496) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 android.app.ActivityThread.access$2200(ActivityThread.java:119) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 android.os.Handler.dispatchMessage(Handler.java:99) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 android.os.Looper.loop(Looper.java:123) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 android.app.ActivityThread.main(ActivityThread.java:4363) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 java.lang.reflect.Method.invokeNative(Native Method) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 java.lang.reflect.Method.invoke(Method.java:521) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 05-30 21:49:29.114:错误/AndroidRuntime(27207):在 dalvik.system.NativeStart.main(本机方法) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 由: java.lang.NullPointerException 引起 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 com.ctg.data.MyDB.getplaces(MyDB.java:82) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 com.ctg.AttractionsListActivity.onCreate(AttractionsListActivity.java:32) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459) 05-30 21:49:29.114: 错误/AndroidRuntime(27207): ... 11 更多 05-30 21:49:29.144:INFO/Process(59):发送信号。PID:27207 SIG:3 05-30 21:49:29.144: INFO/dalvikvm(27207): threadid=7: 对信号 3 做出反应 05-30 21:49:29.174: INFO/dalvikvm(27207): 将堆栈跟踪写入“/data/anr/traces.txt” 05-30 21:49:39.039:WARN/ActivityManager(59):启动超时已过期,放弃唤醒锁! 05-30 21:49:39.057: WARN/ActivityManager(59): HistoryRecord{44eae320 com.ctg/.AttractionsListActivity} 的活动空闲超时