- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图通过游标从数据库检索数据,但出现 NPE。我很确定数据正在被插入到数据库中,因为我已经将同一个数据库用于另一个 Android 应用程序,没有任何问题。我尝试过寻找类似问题的答案,但没有一个能解决我的问题。这是我的代码。
package com.example.testapp;
import mylibs.testshop;
import android.app.Activity;
import android.database.Cursor;
import android.os.Bundle;
import android.util.Log;
import android.widget.*;
public class shopping_list extends Activity {
testshop shop;
String item, type;
int IdCounter = 0;
LinearLayout itemLayout;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.shopping_list);
shop = new testshop(this); // now Initialized shop
showShoppinglist();
}
public void showShoppinglist() {
itemLayout = (LinearLayout) findViewById(R.id.item_list);
// Here's is the cursor that gives the NPE
String[] columns = new String[] { testshop.TABLE_ROW_ID,
testshop.TABLE_ROW_ONE,
testshop.TABLE_ROW_TWO };
Cursor cursor = shop.db.rawQuery(testshop.TABLE_NAME, columns);
cursor.moveToFirst();
if (!cursor.isAfterLast()) {
do {
addItemToList(cursor);
}
while (cursor.moveToNext());
}
cursor.close(); // closing of the cursor
shop.db.close(); // closing the database
}
public void addItemToList(Cursor items) {
RelativeLayout itemListlayout = new RelativeLayout(this);
try {
addItemToitemListLayout(itemListlayout,
items.getString(1),
items.getString(1));
}
catch (Exception e) {
Log.e("additemtolistLAYOUT ERROR", e.toString());
}
itemListlayout.setId(IdCounter++);
itemLayout.addView(itemListlayout);
}
private void addItemToitemListLayout(RelativeLayout itemListlayout,
String string,
String string2) {
TextView textView = new TextView(this);
textView.setText(item);
RelativeLayout.LayoutParams layoutDesc = new RelativeLayout.LayoutParams(
RelativeLayout.LayoutParams.WRAP_CONTENT,
RelativeLayout.LayoutParams.WRAP_CONTENT);
layoutDesc.addRule(RelativeLayout.ALIGN_PARENT_LEFT);
textView.setId(IdCounter++);
TextView textView2 = new TextView(this);
textView2.setText(type);
layoutDesc.addRule(RelativeLayout.RIGHT_OF, textView2.getId());
textView2.setId(IdCounter++);
itemListlayout.addView(textView, layoutDesc);
itemListlayout.addView(textView2, layoutDesc);
}
}
这是我的日志:
03-31 17:23:36.464: E/AndroidRuntime(400): FATAL EXCEPTION: main
03-31 17:23:36.464: E/AndroidRuntime(400): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.testapp/com.example.testapp.shopping_list}: java.lang.StringIndexOutOfBoundsException
03-31 17:23:36.464: E/AndroidRuntime(400): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.app.ActivityThread.access$2300(ActivityThread.java:125)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.os.Handler.dispatchMessage(Handler.java:99)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.os.Looper.loop(Looper.java:123)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.app.ActivityThread.main(ActivityThread.java:4627)
03-31 17:23:36.464: E/AndroidRuntime(400): at java.lang.reflect.Method.invokeNative(Native Method)
03-31 17:23:36.464: E/AndroidRuntime(400): at java.lang.reflect.Method.invoke(Method.java:521)
03-31 17:23:36.464: E/AndroidRuntime(400): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
03-31 17:23:36.464: E/AndroidRuntime(400): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
03-31 17:23:36.464: E/AndroidRuntime(400): at dalvik.system.NativeStart.main(Native Method)
03-31 17:23:36.464: E/AndroidRuntime(400): Caused by: java.lang.StringIndexOutOfBoundsException
03-31 17:23:36.464: E/AndroidRuntime(400): at java.lang.String.substring(String.java:1579)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:66)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.database.sqlite.SQLiteQuery.<init>(SQLiteQuery.java:46)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:42)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1345)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.database.sqlite.SQLiteDatabase.rawQuery(SQLiteDatabase.java:1315)
03-31 17:23:36.464: E/AndroidRuntime(400): at com.example.testapp.shopping_list.showShoppinglist(shopping_list.java:38)
03-31 17:23:36.464: E/AndroidRuntime(400): at com.example.testapp.shopping_list.onCreate(shopping_list.java:30)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-31 17:23:36.464: E/AndroidRuntime(400): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
03-31 17:23:36.464: E/AndroidRuntime(400): ... 11 more
最佳答案
您的商店
为null
。您尚未初始化它。
关于java - 光标为空,给出 NPE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22765805/
目前,我的经验是,一段利用Google Drive API的代码在没有引入ProGuard的情况下运行得很好。。然而,在引入ProGuard之后,我得到了以下运行时错误。。请注意,崩溃发生在我的代码(
今天早上我遇到了一个非常奇怪的 NPE,并将其简化为一个简单的示例。这是 JVM 错误还是正确的行为? public class Test1 { class Item { In
在 crashlytics 中报告的 NPE 仅适用于 Android O 及更高版本。我只是在 onCreate 方法中 startForegroundService 和服务 startForgro
运行以下内容: public class NPESample { String value; public static void main(String[] args) { NPES
我有一个非常简单的 OpenAPI/Swagger 配置 (openapi.yaml): swagger: '2.0' info: title: My Service version: 1.0
我正在使用 com.sun.media.imageioimpl.plugins.tiff.TIFFPackBitsCompressor 尝试对使用 PackBits 的 tiff 字节数组进行编码。我
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) findViewById returns null
我有一个处理大量数据的批处理作业。该作业基本上从源数据库获取数据并进行 Web 服务调用,然后将数据写入目标数据库。今天我遇到了“NPE”,我在其中检查 XML 是否有“成功”响应。我检查其中一个节点
这个问题已经有答案了: Why does a ternary conditional expression returning null and assigned to a reference typ
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 4 年前。 我正在尝试从 bundle 内的
我试图在我的应用程序中每隔一分钟执行一项任务,我使用以下内容来实现相同的目的。代码位于onCreate方法内部: mTimer.scheduleAtFixedRate(new TimerT
所以我正在使用集合设计模式并使用数组列表。每当我尝试向数组列表中添加某些内容时,我都会收到 NPE。我可能错误地实现了该集合,因此出现了 NPE。 我不想复制我的整个代码,因为它太长了,所以我试图给你
我想将自定义对话框的一个区域设置为所选图像。如果我设置整个应用程序的背景图像,下面的代码可以进行一些重新安排。由于某种原因,当我移动它来设置自定义对话框的区域时,我收到以下错误: 错误: 11-03
所以我觉得自己像个白痴,但我正在尝试实现碰撞检测,并且我需要检查玩家旁边是否有方 block 。当我去检查时,我首先会看看我要找的瓷砖是否真的在那里。如果是,我将继续选择该图 block 并从中创建一
在 OS X 10.11 上,我们的应用程序用户会遇到一些没有堆栈跟踪的 NPE(请参阅 this stackoverflow-question)。我现在想自己创建一个来调试这种情况下的错误处理。 如
我有一个非常简单的 OpenAPI/Swagger 配置 (openapi.yaml): swagger: '2.0' info: title: My Service version: 1.0
我正在尝试为名为 getBestSellers() 的方法编写单元测试。 这里是: package bookstore.scraper.book.scrapingtypeservice; import
为什么我在以下作业中获得 NPE: mPyramid[row][column] = temp; 这是我的代码: Block temp; Block[][] pyramid =
为什么这段代码会导致NPE? Findbugs 给了我提示,这种情况可能会发生,而且有时确实会发生:-) 有什么想法吗? public Integer whyAnNPE() { return
我正在尝试运行客户端并访问字段来设置/获取值。当脚本启动时,我创建一个加载了 URLClassLoader 的客户端类的新实例,并将其分配给 gameApplet。 现在,下一段代码可以正常工作(访问
我是一名优秀的程序员,十分优秀!