- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
几天前,我的应用程序在多个设备上停止运行。该代码至少一年没有被触及(即:最近没有进行任何更改)。它从 SplashScreenActivity 开始,从 SQL 数据库下载一些数据,效果很好。之后,这些数据被 putExtra
到用于启动 MainActivity 的 Intent - 这就是应用程序突然关闭的地方。通过调试,我知道 Intent 仍然被正确创建,但在 MainActivity 中“onCreate
”未被调用。我不知道中间是什么以及为什么它停止工作,也许与依赖性有关?有什么想法吗?
下面是 SplashScreen 的代码和 MainActivity 的 onCreate 方法,以及 build.gradle
(应用程序),我在其中做了一些更改试图解决问题(已弃用的编译更改为实现和依赖项的版本和 sdkVersion )。这并没有解决问题。
构建.gradle:
apply plugin: 'com.android.application'
android {
compileSdkVersion 26
buildToolsVersion '26.0.2'
defaultConfig {
applicationId "com.myname.myapp"
minSdkVersion 19
targetSdkVersion 26
versionCode 14
versionName "1.51"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
multiDexEnabled true
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
compileOptions {
targetCompatibility = 1.8
sourceCompatibility = 1.8
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
androidTestImplementation('com.android.support.test.espresso:espresso-core:3.0.2', {
exclude group: 'com.android.support', module: 'support-annotations'
})
implementation 'com.android.support:multidex:1.0.3'
implementation 'com.android.support:appcompat-v7:26.1.0'
implementation 'com.android.support:recyclerview-v7:26.1.0'
implementation 'com.google.android.gms:play-services:12.0.1'
testImplementation 'junit:junit:4.12'
}
启动画面 Activity :
package com.myname.myapp;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.net.ConnectivityManager;
import android.net.NetworkInfo;
import android.os.Bundle;
import android.preference.PreferenceManager;
import android.widget.TextView;
import android.widget.Toast;
import java.util.ArrayList;
public class SplashScreen extends Activity {
private String mAccessCode; // --> DatabaseID
public String getmAccessCode() {
return mAccessCode;
}
public void setmAccessCode(String mAccessCode) {
this.mAccessCode = mAccessCode;
}
private String getPrefsString(String prefName) {
SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(getApplicationContext());
return sharedPreferences.getString(prefName, getString(R.string.default_access_code));
}
public boolean isOnline() {
ConnectivityManager connMgr = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo networkInfo = connMgr.getActiveNetworkInfo();
return (networkInfo != null && networkInfo.isConnected());
}
ArrayList<String> strResult = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_splash);
TextView textViewVersionName = findViewById(R.id.textViewVersionName);
textViewVersionName.setText("Version " + BuildConfig.VERSION_NAME);
setmAccessCode(getPrefsString("AccessCode"));
if (isOnline()) {
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
strResult.add(new DataTransfer().receiveDataFromDatabase(getString(R.string.sql_id_users), "0", getString(R.string.url_receive), getmAccessCode()));
strResult.add(new DataTransfer().receiveDataFromDatabase(getString(R.string.sql_id_ridesByDate), "0", getString(R.string.url_receive), getmAccessCode()));
strResult.add(new DataTransfer().receiveDataFromDatabase(getString(R.string.sql_id_ridesByDriverID), "0", getString(R.string.url_receive), getmAccessCode()));
strResult.add(new DataTransfer().receiveDataFromDatabase(getString(R.string.sql_id_passengersByDate), "0", getString(R.string.url_receive), getmAccessCode()));
Intent i = new Intent(SplashScreen.this, MainActivity.class);
i.putStringArrayListExtra("tableContents", strResult);
startActivity(i);
finish();
}
}, 1500);
} else {
Toast toast = Toast.makeText(getApplicationContext(), R.string.connection_error, Toast.LENGTH_LONG);
toast.show();
finish();
}
}
}
主要 Activity :
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Intent i = getIntent();
ArrayList<String> tableContents = i.getStringArrayListExtra("tableContents");
initActivity(tableContents);
}
如果还有什么需要补充的,欢迎留言。感谢您的帮助!
编辑:这是日志
2019-09-17 10:25:35.127 13305-13305/? I/name.myap: Not late-enabling -Xcheck:jni (already on)
2019-09-17 10:25:35.151 13305-13305/? E/name.myap: Unknown bits set in runtime_flags: 0x8000
2019-09-17 10:25:35.153 13305-13305/? W/name.myap: Unexpected CPU variant for X86 using defaults: x86
2019-09-17 10:25:35.230 13305-13305/? I/name.myap: The ClassLoaderContext is a special shared library.
2019-09-17 10:25:36.608 13305-13305/com.myname.myapp I/MultiDex: VM with version 2.1.0 has multidex support
2019-09-17 10:25:36.608 13305-13305/com.myname.myapp I/MultiDex: Installing application
2019-09-17 10:25:36.608 13305-13305/com.myname.myapp I/MultiDex: VM has multidex support, MultiDex support library is disabled.
2019-09-17 10:25:36.626 13305-13305/com.myname.myapp I/FirebaseInitProvider: FirebaseApp initialization unsuccessful
2019-09-17 10:25:36.644 13305-13338/com.myname.myapp D/libEGL: Emulator has host GPU support, qemu.gles is set to 1.
2019-09-17 10:25:36.644 13305-13338/com.myname.myapp W/libc: Unable to set property "qemu.gles" to "1": connection failed; errno=13 (Permission denied)
2019-09-17 10:25:36.634 13305-13305/com.myname.myapp W/RenderThread: type=1400 audit(0.0:70): avc: denied { write } for name="property_service" dev="tmpfs" ino=6782 scontext=u:r:untrusted_app_27:s0:c512,c768 tcontext=u:object_r:property_socket:s0 tclass=sock_file permissive=0
2019-09-17 10:25:36.703 13305-13338/com.myname.myapp D/libEGL: loaded /vendor/lib/egl/libEGL_emulation.so
2019-09-17 10:25:36.710 13305-13338/com.myname.myapp D/libEGL: loaded /vendor/lib/egl/libGLESv1_CM_emulation.so
2019-09-17 10:25:36.719 13305-13338/com.myname.myapp D/libEGL: loaded /vendor/lib/egl/libGLESv2_emulation.so
2019-09-17 10:25:36.803 13305-13341/com.myname.myapp D/NetworkSecurityConfig: No Network Security Config specified, using platform default
2019-09-17 10:25:36.831 13305-13336/com.myname.myapp W/OpenGLRenderer: Failed to choose config with EGL_SWAP_BEHAVIOR_PRESERVED, retrying without...
2019-09-17 10:25:36.862 13305-13336/com.myname.myapp D/eglCodecCommon: setVertexArrayObject: set vao to 0 (0) 0 0
2019-09-17 10:25:36.862 13305-13336/com.myname.myapp D/EGL_emulation: eglCreateContext: 0xe5bf00a0: maj 2 min 0 rcv 2
2019-09-17 10:25:36.872 13305-13336/com.myname.myapp D/EGL_emulation: eglMakeCurrent: 0xe5bf00a0: ver 2 0 (tinfo 0xf0da9bd0)
2019-09-17 10:25:36.903 13305-13336/com.myname.myapp W/Gralloc3: mapper 3.x is not supported
2019-09-17 10:25:36.925 13305-13336/com.myname.myapp D/EGL_emulation: eglMakeCurrent: 0xe5bf00a0: ver 2 0 (tinfo 0xf0da9bd0)
2019-09-17 10:25:36.947 13305-13336/com.myname.myapp D/eglCodecCommon: setVertexArrayObject: set vao to 0 (0) 1 0
编辑 2:现在有一条新的错误消息可能会有所帮助:
2019-09-17 13:28:13.400 1669-2304/? E/ActivityManager: Second failure launching com.myname.myapp/.MainActivity, giving up
android.os.TransactionTooLargeException: data parcel size 520984 bytes
at android.os.BinderProxy.transactNative(Native Method)
at android.os.BinderProxy.transact(Binder.java:748)
at android.app.IApplicationThread$Stub$Proxy.scheduleLaunchActivity(IApplicationThread.java:1230)
at com.android.server.am.ActivityStackSupervisor.realStartActivityLocked(ActivityStackSupervisor.java:1467)
at com.android.server.am.ActivityStackSupervisor.attachApplicationLocked(ActivityStackSupervisor.java:972)
at com.android.server.am.ActivityManagerService.attachApplicationLocked(ActivityManagerService.java:6958)
at com.android.server.am.ActivityManagerService.attachApplication(ActivityManagerService.java:7025)
at android.app.IActivityManager$Stub.onTransact(IActivityManager.java:291)
at com.android.server.am.ActivityManagerService.onTransact(ActivityManagerService.java:2935)
at android.os.Binder.execTransact(Binder.java:674)
2019-09-17 13:28:13.434 1669-1690/? E/ViewRootImpl[myapp]: Attempting to destroy the window while drawing!
window=android.view.ViewRootImpl@da270ff, title=Splash Screen com.myname.myapp
最佳答案
您尚未共享 Logcat 错误堆栈,这将有助于进一步了解该问题。但似乎您正在尝试从新线程而不是 UI 线程启动 Activity ,因此应用程序崩溃,只需移出可运行 run 方法内的代码,并且不要启动新线程。如果由于某种原因您希望代码异步运行,请通过处理程序运行您的 Runnable。下面是 fragment
if (isOnline()) {
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
strResult.add(new DataTransfer().receiveDataFromDatabase(getString(R.string.sql_id_users), "0", getString(R.string.url_receive), getmAccessCode()));
strResult.add(new DataTransfer().receiveDataFromDatabase(getString(R.string.sql_id_ridesByDate), "0", getString(R.string.url_receive), getmAccessCode()));
strResult.add(new DataTransfer().receiveDataFromDatabase(getString(R.string.sql_id_ridesByDriverID), "0", getString(R.string.url_receive), getmAccessCode()));
strResult.add(new DataTransfer().receiveDataFromDatabase(getString(R.string.sql_id_passengersByDate), "0", getString(R.string.url_receive), getmAccessCode()));
Intent i = new Intent(SplashScreen.this, MainActivity.class);
i.putStringArrayListExtra("tableContents", strResult);
startActivity(i);
finish();
}
},1000);
}
关于java - 尽管没有对代码进行任何更改,但 MainActivity 不再从 startActivity(i) 启动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57970078/
我几天前开始进行android开发。我实现了一个 recylerview,在 recyclerview 适配器的 OnBindViewHolder 方法中,我在 recyclerview 项目上使用了
我已阅读文章https://github.com/Kotlin/anko/wiki/Anko-Commons-%E2%80%93-Intents . 我可以使用 startActivity(inten
我的 BroadcastReceiver 的 onReceive 函数中有以下代码。 public void onReceive(Context context, Intent intent) {
无论我做什么,我都无法开始新 Activity 。我重新下载了所有的Android SDK。我重新下载了Eclipse并再次安装了ADT插件 错误日志 09-16 17:53:51.537: W/II
我有以下 Activity ,当调用 startactivity() 时,应用程序被强制关闭,我已经搜索了几天失败的原因,有人可以帮助我吗? 应用程序: package com.example.dec
我是 Android 开发新手,在创建新 Activity 时遇到问题。 我想在开始之前使用我的 Activity 。例如,我已经尝试过: MyActivity menu = new MyActivi
在我的应用程序菜单类中,我想要一个按钮来启动 Activity 。这不适用于 StartActivity() 方法,因为它根本不是 Activity 的子类。那我该怎么办呢? 如果你读过《Beginn
我对 Android/Java 完全陌生。我正在尝试创建一个应用程序来连接到我的 TCP 服务器以从 mySQL 获取数据。 我有以下内容:MainActivity - 这是登录屏幕。输入用户名和密码
我刚刚开始 Android 开发,我被这段代码困住了: public class Home extends Activity { /** Called when the activity is
我有一个对话框提示用户确认删除。 在用户点击删除后弹出一个简单的警告。我需要重定向到一个新 Activity ,但在我有机会在确认警报上单击“确定”之前,startActivity 已触发。我在它搞砸
为什么要在服务中使用 startActivity()?如果我需要一个 Activity 必须调用一个 Activity ,如果我需要一个“延迟 Activity ”我必须使用通知。那么,我为什么要使用
引擎盖下发生了什么?这会以某种方式传递给操作系统,并且表明操作系统会找到正确的 Activity/Activity 并启动它?是否有在 Android 中运行的服务/库来处理这个?我正在尝试修改操作系
我有一个主类和一个单独的类 (OnClickBtn.java),我只想在其中保留按钮方法。我不想从主类而是从 OnClickBtn.java 开始新的 Activity 。 我已经运行了该程序,但它在
我正在学习 android 开发。这只是示例项目。所以我在按钮点击事件上创建了相同的 Activity (见代码)。在第一个 Activity 之后,我可以看到带有“qwerty”文本的新 Activ
我已经设置了一个从菜单按钮执行的 Activity 。 Activity 启动并短暂出现然后崩溃。我已将附加 Activity 添加到 list 文件。代码如下。我最近从 Eclipse 切换到 An
我试图从 OptionsMenu 启动一个 Activity ,但它没有启动。为什么? @Override public boolean onOptionsItemSelected(MenuItem
我创建了一个 activity( Activity 编号 1),其中包含 2 个 Views、一个 button 和一个 textView这两个 View 被共享到另一个activity(activi
截至今天上午,我已经尝试整合足够的知识来制作一个非常基本的应用程序来演示一个概念。这个想法是显示谷歌地图,用户按下他们想要添加标记的位置,然后弹出一个屏幕,他们可以在其中填写更多信息,然后当有人点击该
我正在制作一个绘图应用程序并想分享图像。但是,我遇到了 startActivity 部分的错误,其中错误写道 The method startActivity(Intent) is undefined
调用 startActivity 时,我一直收到 NPE,我认为这与我提供给 Intent 的上下文有关。当我从 Internet 获取 xml 数据时,我试图让启动画面保持不变。 splash Ac
我是一名优秀的程序员,十分优秀!