Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/354.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Android:虚拟监视器和真实手机问题_Java_Android - Fatal编程技术网

Java Android:虚拟监视器和真实手机问题

Java Android:虚拟监视器和真实手机问题,java,android,Java,Android,昨晚到现在为止,我面临着一个严重的问题,这个项目(带有外部数据库)在虚拟监视器中运行得非常好 API 22,安卓1.5(谷歌API) 但如果我用手机跑过去 (安卓5.1,API 22) 它返回一个错误: E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.hamira.wordmatchinggame, PID: 12466 java.lang.Runti

昨晚到现在为止,我面临着一个严重的问题,这个项目(带有外部数据库)在虚拟监视器中运行得非常好

API 22,安卓1.5(谷歌API)

但如果我用手机跑过去

(安卓5.1,API 22)

它返回一个错误:

E/AndroidRuntime: FATAL EXCEPTION: main
                  Process: com.example.hamira.wordmatchinggame, PID: 12466
                  java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.hamira.wordmatchinggame/com.example.hamira.wordmatchinggame.LeaderBoard}: android.database.sqlite.SQLiteException: no such table: player (code 1): , while compiling: SELECT _id, pname, escr, dscr, hscr, tscr FROM player ORDER BY tscr DESC
                      at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2525)
                      at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2617)
                      at android.app.ActivityThread.access$800(ActivityThread.java:182)
                      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1474)
                      at android.os.Handler.dispatchMessage(Handler.java:111)
                      at android.os.Looper.loop(Looper.java:218)
                      at android.app.ActivityThread.main(ActivityThread.java:5657)
                      at java.lang.reflect.Method.invoke(Native Method)
                      at java.lang.reflect.Method.invoke(Method.java:372)
                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:990)
                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:785)
                   Caused by: android.database.sqlite.SQLiteException: no such table: player (code 1): , while compiling: SELECT _id, pname, escr, dscr, hscr, tscr FROM player ORDER BY tscr DESC
                      at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
                      at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:898)
                      at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:509)
                      at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
                      at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58)
                      at android.database.sqlite.SQLiteQuery.<init>(SQLiteQuery.java:37)
                      at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:44)
                      at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1346)
                      at android.database.sqlite.SQLiteDatabase.queryWithFactory(SQLiteDatabase.java:1193)
                      at android.database.sqlite.SQLiteDatabase.query(SQLiteDatabase.java:1064)
                      at android.database.sqlite.SQLiteDatabase.query(SQLiteDatabase.java:1270)
                      at com.example.hamira.wordmatchinggame.DataConn.displayLeaderBoard(DataConn.java:187)
                      at com.example.hamira.wordmatchinggame.LeaderBoard.list(LeaderBoard.java:79)
                      at com.example.hamira.wordmatchinggame.LeaderBoard.onCreate(LeaderBoard.java:35)
                      at android.app.Activity.performCreate(Activity.java:6135)
                      at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1112)
                      at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2472)
                      at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2617) 
                      at android.app.ActivityThread.access$800(ActivityThread.java:182) 
                      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1474) 
                      at android.os.Handler.dispatchMessage(Handler.java:111) 
                      at android.os.Looper.loop(Looper.java:218) 
                      at android.app.ActivityThread.main(ActivityThread.java:5657) 
                      at java.lang.reflect.Method.invoke(Native Method) 
                      at java.lang.reflect.Method.invoke(Method.java:372) 
                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:990) 
                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:785) 
I/Process: Sending signal. PID: 12466 SIG: 9
Application terminated.
附加: 我不认为我的代码有问题,因为如果有问题,那么为什么它在VM(API 22)中运行得很好呢?? 它在我的
AndroidManifest.xml
中吗?或者是
Build.Gradle?

AndroidManifest.xml

已编辑 我删除onCreate((SQLiteDatabase db)方法上的
db.close()
,并向其他游标方法返回另一个错误

错误日志:

          android.database.sqlite.SQLiteException: no such column: stats (code 1): , while compiling: UPDATE player SET stats = '0'
游标方法:

public Cursor ClearRecentPlayer() {
    db = this.getWritableDatabase();
    Cursor c = db.rawQuery("UPDATE player SET stats = '0'", null);
    c.moveToFirst();
    c.close();
    return c;
}

首先,我必须指出您的
SQLiteOpenHelper
有点奇怪。如果您使用此代码,您可能会面临一些奇怪的问题

我不知道您错误的详细信息,但我非常确定在
onCreate
中关闭数据库是不正确的

我强烈建议您阅读以下内容:,并使用为您的项目编写的标准
SQLiteOpenHelper
。这不会占用您太多时间

关于您的另一个问题,我认为在您完成新标准
SQLiteOpenHelper
之后,您将不会面对它


希望这能对您有所帮助。

首先,我必须指出您的
SQLiteOpenHelper
有点奇怪。如果您使用此代码,您可能会遇到一些奇怪的问题

我不知道您错误的详细信息,但我非常确定在
onCreate
中关闭数据库是不正确的

我强烈建议您阅读以下内容:,并使用为您的项目编写的标准
SQLiteOpenHelper
。这不会占用您太多时间

关于您的另一个问题,我认为在您完成新标准
SQLiteOpenHelper
之后,您将不会面对它


希望这能帮到你。

你想要什么都行。我现在只需要解决这个问题。我累了:((请帮忙你能发布你的数据库助手类吗?L.Swifter完成了。我已经编辑了我的帖子。它在DataConn.javapost中。请发布你所有的错误日志。但是上次我做了一个简单的基本游戏,我从来没有遇到过像丢失重要权限这样的情况。所有的运行都很好。这是我的第二个应用程序,无论你想要什么。我只需要解决它。)(请帮我发布你的数据库助手类好吗?L.Swifter完成了。我已经编辑了我的帖子。请在DataConn.javapost中发布你所有的错误日志。但是上次我做了一个简单的基本游戏,我从来没有经历过像丢失重要权限这样的情况。所有的运行都很好。这是我制作的第二个应用程序
package="com.example.hamira.wordmatchinggame">

<application
    android:allowBackup="true"
    android:icon="@mipmap/launcher"

    android:label="@string/app_name"
    android:theme="@style/Theme.AppCompat.Light.NoActionBar">
    <uses-sdk
        android:targetSdkVersion="23"
        android:minSdkVersion="7"
        />
    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <activity
        android:name=".ingameinterface"
        android:label="@string/app_name">
    </activity>
    <activity
        android:name=".MenuView"
        android:label="@string/app_name">
    </activity>
    <activity
        android:name=".PlayerView"
        android:label="@string/app_name">
    </activity>
    <activity
        android:name=".LevelView"
        android:label="@string/app_name">
    </activity>
    <activity
        android:name=".ingamedifficult"
        android:label="@string/app_name">
    </activity>
    <activity
        android:name=".LeaderBoard"
        android:label="@string/app_name">
    </activity>

</application>
apply plugin: 'com.android.application'

android {
    compileSdkVersion 23
    buildToolsVersion "23.0.1"

    defaultConfig {
        applicationId "com.example.hamira.wordmatchinggame"
        minSdkVersion 7
        targetSdkVersion 23
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:23.4.0'
    compile 'com.readystatesoftware.sqliteasset:sqliteassethelper:+'

}
          android.database.sqlite.SQLiteException: no such column: stats (code 1): , while compiling: UPDATE player SET stats = '0'
public Cursor ClearRecentPlayer() {
    db = this.getWritableDatabase();
    Cursor c = db.rawQuery("UPDATE player SET stats = '0'", null);
    c.moveToFirst();
    c.close();
    return c;
}