gpt4 book ai didi

java - 从手机运行时应用程序崩溃,但从计算机启动时运行正常

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:11:16 24 4
gpt4 key购买 nike

经过 3 天的工作,我已经能够让一个旧应用程序在我的设备上运行!但只有当命令来 self 的电脑时...

我解释一下。当我在手机上从 Android Studio 启动该应用程序时,它可以正常启动,这非常棒。但是当我直接从我的手机启动它时,我在 Catlog 中看到一个字符串为空。我不明白是什么原因造成的。当应用程序从我的电脑启动但不是从手机启动时,它工作正常......

请帮忙!

编辑 1:添加 AndroidManifest.xml Activity

<activity android:name=".LoginActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity android:name=".ManageAccountActivity"/>
<activity android:name=".RegionListActivity"/>
<activity android:name=".ClubListActivity"/>
<activity android:name=".SearchActivity"/>
<activity android:name=".TeetimesListActivity"/>
<activity android:name=".ConfirmationActivity"/>
<activity android:name=".TermsAndConditionsActivity"/>
<activity android:name=".TabletSearchActivity"/>
<activity android:name=".TabletConfirmationActivity"/>
<activity android:name=".PreferencesActivity"/>

编辑 2:错误日志

01-08 16:08:47.194 26704-26704/ca.gggolf.aminutegolf E/ACRA: ACRA caught a RuntimeException for ca.gggolf.aminutegolf
java.lang.RuntimeException: Unable to start activity ComponentInfo{ca.gggolf.aminutegolf/ca.gggolf.aminutegolf.LoginActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String[] java.lang.String.split(java.lang.String)' on a null object reference
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2339)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2413)
at android.app.ActivityThread.access$800(ActivityThread.java:155)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1317)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5343)
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:905)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String[] java.lang.String.split(java.lang.String)' on a null object reference
at ca.gggolf.aminutegolf.LoginActivity.checkForNewBooking(LoginActivity.java:676)
at ca.gggolf.aminutegolf.LoginActivity.onCreate(LoginActivity.java:112)
at android.app.Activity.performCreate(Activity.java:6010)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1129)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2292)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2413) 
at android.app.ActivityThread.access$800(ActivityThread.java:155) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1317) 
at android.os.Handler.dispatchMessage(Handler.java:102) 
at android.os.Looper.loop(Looper.java:135) 
at android.app.ActivityThread.main(ActivityThread.java:5343) 
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:905) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700) 

修改3:添加包含错误的部分代码

private void checkForNewBooking() {
Bundle extras = getIntent().getExtras();
if (extras != null) {
final String numConfirmation = extras.getString("NEWLY_BOOKED");
final String date[] = extras.getString("BOOKING_DATE").split("-"); //line 676
final String time[] = extras.getString("BOOKING_TIME").split(":");
final String club = extras.getString("BOOKING_CLUB");
final int hole = Integer.parseInt(extras.getString("BOOKING_HOLE"));

编辑 4:更多代码。这是 onCreate() 方法。方法 checkForNewBooking() 的调用来自那里。

public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.login);
Log.d(TAG, "onCreate()");

mController = new ActivityController(this);

// Setting server mode
((Globals) getApplication()).setServerInformation(SharedPrefManager.getServer(this));

// Hide auto-triggered keyboard
this.getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);
if (SharedPrefManager.isFirstRun(LoginActivity.this)) {
SharedPrefManager.setFirstTimePrefs(LoginActivity.this, Utility.retreiveLanguage());
Log.d(TAG, "First run triggered.");
}

Bundle mBundle = getIntent().getExtras();
if (mBundle != null) {
if (mBundle.getBoolean("PROCESS_KILLED")) {
Toast.makeText(LoginActivity.this, R.string.ui_error_killedprocess, Toast.LENGTH_LONG).show();
} else {
checkForNewBooking();
}
}
initializeUI();

WrappedLogger.setProvider(new LoggingProvider());
WrappedLogger.setMemoryLog(false);
IPAddressInformation.getInstance().getIPAddress();
}

最佳答案

所以这不是一个完整的 super 答案,但我已经能够通过更改 checkForNewBooking() 中的第一个 if 语句简单地修复这个错误。现在是:

if(extras.getString("BOOKING_DATE") != null)

代替

if(extras != null)

我真的不知道为什么这个程序是从这个开始的。我发布的部分类(class)是主要类(class),在一开始就启动,所以信息不是来自那里。根据我前面那个人的评论,这个方法是为了检查过去是否已经完成预订,这意味着一旦预订完成,BOOKING_DATE 和 BOOKING_TIME 所需的信息可能来自另一个方法。

无论如何,现在可以了!谢谢大家的帮助!

关于java - 从手机运行时应用程序崩溃,但从计算机启动时运行正常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34685583/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com