- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我认为我的标题不足以解释我的 android 何时会崩溃。我的应用程序上有 3 个选项卡小部件。这意味着我有 3 个 Activity (accountMainThread.java、TodayExpenseList.java 和 settingThread)适应每个选项卡小部件。这是我的选项卡 Activity 代码。
TabSpec mainSpec = addNewTab(tab1,android.R.drawable.ic_menu_upload);
Intent mainIntent = new Intent(AccountTabActivity.this,accountMainThread.class);
mainSpec.setContent(mainIntent);
tabHost.addTab(mainSpec);
TabSpec todayExpenseListSpec = addNewTab(tab2,android.R.drawable.ic_menu_today);
Intent todayExpenseListIntent = new Intent(AccountTabActivity.this,TodayExpenseList.class);
todayExpenseListSpec.setContent(todayExpenseListIntent);
tabHost.addTab(todayExpenseListSpec);
TabSpec settingSpec = addNewTab(tab3,android.R.drawable.ic_menu_manage);
Intent settingIntent = new Intent(AccountTabActivity.this,settingThread.class);
settingSpec.setContent(settingIntent);
tabHost.addTab(settingSpec);
这只是我工作的一部分。好吧,我的应用程序将从第一个选项卡 (accountMainThread) 开始,并且应用程序运行良好。然后,我选择第二个选项卡 (todayExpenseList),仍然是一样的,没有错。然后,我选择第三个选项卡(settingThread)并且仍然相同,没有错。问题是当我为下一个选项卡选择任何选项卡时,第一个选项卡或第二个选项卡或第三个选项卡,我的应用程序崩溃了。我希望我的解释足够理解。
这是我完整的 tabActivity 代码
public class AccountTabActivity extends TabActivity {
private String[] idItem;
private static connectionDatabase dbConnect;
private static SQLLiteAdapter mDbHelper;
private static int totalTodayExpense = 0;
private static String tab1 = "Send Expense";
private static String tab2 = "Today Expense";
private static String tab3 = "Setting";
private static TabHost tabHost;
private static int dataProcessed = 0;
private static RelativeLayout startupLayout;
private static ProgressBar startupProgress;
private static TextView startupText;
private int progressValues[] = {0,50,70,90,98,100};
private String startupSequences[] = {
"Initializing",
"Connecting database",
"Initializing array list",
"Retrieving data",
"Synchronizing data with server",
"Setting up UI thread"
};
@Override
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
//-----------------------------------------------
setContentView(R.layout.android_tab_activity);
startupLayout = (RelativeLayout)findViewById(R.id.startup_layout);
startupProgress = (ProgressBar)findViewById(R.id.startup_progressbar);
startupText = (TextView)findViewById(R.id.startup_textview);
tabHost = getTabHost(); /*
tabHost.setOnTabChangedListener(new OnTabChangeListener(){
@Override
public void onTabChanged(String tabId) {
//setTabColor(tabHost);
}
});
*/
new readyTabActivity().execute();
dataProcessed = 1;
}
public void setTabColor(TabHost tabhost){
for(int i=0;i<tabhost.getTabWidget().getChildCount();i++){
tabhost.getTabWidget().getChildAt(i).setBackgroundResource(R.drawable.not_select);
}
tabhost.getTabWidget().getChildAt(tabhost.getCurrentTab())
.setBackgroundResource(R.drawable.selected);
}
private class readyTabActivity extends AsyncTask<String,Integer,Void>{
private int connectedFlag = 0;
private JSONArray jsonArray;
private int dataHavenSyncYet = 0;
private SQLLiteAdapter mDbHelper;
@Override
protected void onPreExecute(){
startupProgress.setProgress(progressValues[0]);
}
protected Void doInBackground(String... url){
try{
dbConnect = new connectionDatabase();
mDbHelper = new SQLLiteAdapter(AccountTabActivity.this);
mDbHelper.open();
publishProgress(1);
List<NameValuePair> params = new ArrayList<NameValuePair>();
publishProgress(1);
JSONObject jsonObject = dbConnect.HttpRequest(dbConnect.url_readData, "get",params);
publishProgress(2);
if(jsonObject.getBoolean("list")){
connectedFlag = 1;
jsonArray = (JSONArray)jsonObject.get("list");
}else{
connectedFlag = 0;
}
publishProgress(3);
}catch(Exception e){
connectedFlag = 0;
Log.e("Icreate", "error on database : " + e.toString());
}
return null;
}
@Override
protected void onPostExecute(Void result)
{
startupLayout.setVisibility(View.GONE);
////////////////////////////////////////////////////////////////
// main Thread
TabSpec mainSpec = addNewTab(tab1,android.R.drawable.ic_menu_upload);
Intent mainIntent = new Intent(AccountTabActivity.this,accountMainThread.class);
mainSpec.setContent(mainIntent);
mainIntent.putExtra("CONNECT", connectedFlag);
tabHost.addTab(mainSpec);
TabSpec todayExpenseListSpec = addNewTab(tab2,android.R.drawable.ic_menu_today);
Intent todayExpenseListIntent = new Intent(AccountTabActivity.this,TodayExpenseList.class);
todayExpenseListSpec.setContent(todayExpenseListIntent);
todayExpenseListIntent.putExtra("CONNECT", connectedFlag);
tabHost.addTab(todayExpenseListSpec);
////////////////////////////////////////////////////////////////
// setting Thread
TabSpec settingSpec = addNewTab(tab3,android.R.drawable.ic_menu_manage);
Intent settingIntent = new Intent(AccountTabActivity.this,settingThread.class);
ArrayList<Map<String,String>> arraySTList =
(ArrayList<Map<String,String>>)buildSettingThreadData();
settingIntent.putExtra("CONNECT", connectedFlag);
settingIntent.putExtra("array_st_list", arraySTList);
settingSpec.setContent(settingIntent);
tabHost.addTab(settingSpec);
/////////////////////////////////////////////////////
// add tab to tabHost
}
@Override
protected void onProgressUpdate(Integer... values){
startupProgress.setProgress(progressValues[values[0]]);
startupText.setText(""+startupSequences[values[0]]);
}
private TabSpec addNewTab(String title, int drawable){
TabHost.TabSpec mainSpec = tabHost.newTabSpec(title);
View tabIndicator = LayoutInflater.from(AccountTabActivity.this).inflate(R.layout.tab_indicator,getTabWidget(),false);
TextView title_text = (TextView)tabIndicator.findViewById(R.id.title);
title_text.setText(title);
ImageView icon = (ImageView)tabIndicator.findViewById(R.id.icon);
icon.setImageResource(drawable);
mainSpec.setIndicator(tabIndicator);
return mainSpec;
}
private ArrayList<Map<String, String>> buildSettingThreadData(){
ArrayList<Map<String, String>> list = new ArrayList<Map<String, String>>();
list.add(putSTData("Database State",dbConnect.connectionState));
list.add(putSTData("URL Retrieve Data",dbConnect.url_readData));
list.add(putSTData("URL Insert Data",dbConnect.url_insertData));
list.add(putSTData("URL Delete Data",dbConnect.url_deleteData));
list.add(putSTData("Creator","Lik Wee"));
return list;
}
private HashMap<String, String> putSTData(String title, String content) {
HashMap<String, String> item = new HashMap<String, String>();
item.put("title", title);
item.put("content", content);
return item;
}
}
}
这是我崩溃后的日志(我删除了应用程序崩溃前的部分)
03-20 13:08:16.742: E/ActivityThread(661): Service com.android.exchange.ExchangeService has leaked ServiceConnection com.android.emailcommon.service.ServiceProxy$ProxyConnection@40cefa88 that was originally bound here
03-20 13:08:16.742: E/ActivityThread(661): android.app.ServiceConnectionLeaked: Service com.android.exchange.ExchangeService has leaked ServiceConnection com.android.emailcommon.service.ServiceProxy$ProxyConnection@40cefa88 that was originally bound here
03-20 13:08:16.742: E/ActivityThread(661): at android.app.LoadedApk$ServiceDispatcher.<init>(LoadedApk.java:969)
03-20 13:08:16.742: E/ActivityThread(661): at android.app.LoadedApk.getServiceDispatcher(LoadedApk.java:863)
03-20 13:08:16.742: E/ActivityThread(661): at android.app.ContextImpl.bindService(ContextImpl.java:1418)
03-20 13:08:16.742: E/ActivityThread(661): at android.app.ContextImpl.bindService(ContextImpl.java:1407)
03-20 13:08:16.742: E/ActivityThread(661): at android.content.ContextWrapper.bindService(ContextWrapper.java:473)
03-20 13:08:16.742: E/ActivityThread(661): at com.android.emailcommon.service.ServiceProxy.setTask(ServiceProxy.java:157)
03-20 13:08:16.742: E/ActivityThread(661): at com.android.emailcommon.service.ServiceProxy.setTask(ServiceProxy.java:145)
03-20 13:08:16.742: E/ActivityThread(661): at com.android.emailcommon.service.AccountServiceProxy.getDeviceId(AccountServiceProxy.java:116)
03-20 13:08:16.742: E/ActivityThread(661): at com.android.exchange.ExchangeService.getDeviceId(ExchangeService.java:1249)
03-20 13:08:16.742: E/ActivityThread(661): at com.android.exchange.ExchangeService$7.run(ExchangeService.java:1856)
03-20 13:08:16.742: E/ActivityThread(661): at com.android.emailcommon.utility.Utility$2.doInBackground(Utility.java:551)
03-20 13:08:16.742: E/ActivityThread(661): at com.android.emailcommon.utility.Utility$2.doInBackground(Utility.java:549)
03-20 13:08:16.742: E/ActivityThread(661): at android.os.AsyncTask$2.call(AsyncTask.java:287)
03-20 13:08:16.742: E/ActivityThread(661): at java.util.concurrent.FutureTask.run(FutureTask.java:234)
03-20 13:08:16.742: E/ActivityThread(661): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
03-20 13:08:16.742: E/ActivityThread(661): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
03-20 13:08:16.742: E/ActivityThread(661): at java.lang.Thread.run(Thread.java:856)
03-20 13:08:16.753: E/StrictMode(661): null
03-20 13:08:16.753: E/StrictMode(661): android.app.ServiceConnectionLeaked: Service com.android.exchange.ExchangeService has leaked ServiceConnection com.android.emailcommon.service.ServiceProxy$ProxyConnection@40cefa88 that was originally bound here
03-20 13:08:16.753: E/StrictMode(661): at android.app.LoadedApk$ServiceDispatcher.<init>(LoadedApk.java:969)
03-20 13:08:16.753: E/StrictMode(661): at android.app.LoadedApk.getServiceDispatcher(LoadedApk.java:863)
03-20 13:08:16.753: E/StrictMode(661): at android.app.ContextImpl.bindService(ContextImpl.java:1418)
03-20 13:08:16.753: E/StrictMode(661): at android.app.ContextImpl.bindService(ContextImpl.java:1407)
03-20 13:08:16.753: E/StrictMode(661): at android.content.ContextWrapper.bindService(ContextWrapper.java:473)
03-20 13:08:16.753: E/StrictMode(661): at com.android.emailcommon.service.ServiceProxy.setTask(ServiceProxy.java:157)
03-20 13:08:16.753: E/StrictMode(661): at com.android.emailcommon.service.ServiceProxy.setTask(ServiceProxy.java:145)
03-20 13:08:16.753: E/StrictMode(661): at com.android.emailcommon.service.AccountServiceProxy.getDeviceId(AccountServiceProxy.java:116)
03-20 13:08:16.753: E/StrictMode(661): at com.android.exchange.ExchangeService.getDeviceId(ExchangeService.java:1249)
03-20 13:08:16.753: E/StrictMode(661): at com.android.exchange.ExchangeService$7.run(ExchangeService.java:1856)
03-20 13:08:16.753: E/StrictMode(661): at com.android.emailcommon.utility.Utility$2.doInBackground(Utility.java:551)
03-20 13:08:16.753: E/StrictMode(661): at com.android.emailcommon.utility.Utility$2.doInBackground(Utility.java:549)
03-20 13:08:16.753: E/StrictMode(661): at android.os.AsyncTask$2.call(AsyncTask.java:287)
03-20 13:08:16.753: E/StrictMode(661): at java.util.concurrent.FutureTask.run(FutureTask.java:234)
03-20 13:08:16.753: E/StrictMode(661): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
03-20 13:08:16.753: E/StrictMode(661): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
03-20 13:08:16.753: E/StrictMode(661): at java.lang.Thread.run(Thread.java:856)
03-20 13:08:16.762: E/ActivityThread(661): Service com.android.exchange.ExchangeService has leaked ServiceConnection com.android.emailcommon.service.ServiceProxy$ProxyConnection@40d2af40 that was originally bound here
03-20 13:08:16.762: E/ActivityThread(661): android.app.ServiceConnectionLeaked: Service com.android.exchange.ExchangeService has leaked ServiceConnection com.android.emailcommon.service.ServiceProxy$ProxyConnection@40d2af40 that was originally bound here
03-20 13:08:16.762: E/ActivityThread(661): at android.app.LoadedApk$ServiceDispatcher.<init>(LoadedApk.java:969)
03-20 13:08:16.762: E/ActivityThread(661): at android.app.LoadedApk.getServiceDispatcher(LoadedApk.java:863)
03-20 13:08:16.762: E/ActivityThread(661): at android.app.ContextImpl.bindService(ContextImpl.java:1418)
03-20 13:08:16.762: E/ActivityThread(661): at android.app.ContextImpl.bindService(ContextImpl.java:1407)
03-20 13:08:16.762: E/ActivityThread(661): at android.content.ContextWrapper.bindService(ContextWrapper.java:473)
03-20 13:08:16.762: E/ActivityThread(661): at com.android.emailcommon.service.ServiceProxy.setTask(ServiceProxy.java:157)
03-20 13:08:16.762: E/ActivityThread(661): at com.android.emailcommon.service.ServiceProxy.setTask(ServiceProxy.java:145)
03-20 13:08:16.762: E/ActivityThread(661): at com.android.emailcommon.service.ServiceProxy.test(ServiceProxy.java:191)
03-20 13:08:16.762: E/ActivityThread(661): at com.android.exchange.ExchangeService$7.run(ExchangeService.java:1850)
03-20 13:08:16.762: E/ActivityThread(661): at com.android.emailcommon.utility.Utility$2.doInBackground(Utility.java:551)
03-20 13:08:16.762: E/ActivityThread(661): at com.android.emailcommon.utility.Utility$2.doInBackground(Utility.java:549)
03-20 13:08:16.762: E/ActivityThread(661): at android.os.AsyncTask$2.call(AsyncTask.java:287)
03-20 13:08:16.762: E/ActivityThread(661): at java.util.concurrent.FutureTask.run(FutureTask.java:234)
03-20 13:08:16.762: E/ActivityThread(661): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
03-20 13:08:16.762: E/ActivityThread(661): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
03-20 13:08:16.762: E/ActivityThread(661): at java.lang.Thread.run(Thread.java:856)
03-20 13:08:16.772: E/StrictMode(661): null
03-20 13:08:16.772: E/StrictMode(661): android.app.ServiceConnectionLeaked: Service com.android.exchange.ExchangeService has leaked ServiceConnection com.android.emailcommon.service.ServiceProxy$ProxyConnection@40d2af40 that was originally bound here
03-20 13:08:16.772: E/StrictMode(661): at android.app.LoadedApk$ServiceDispatcher.<init>(LoadedApk.java:969)
03-20 13:08:16.772: E/StrictMode(661): at android.app.LoadedApk.getServiceDispatcher(LoadedApk.java:863)
03-20 13:08:16.772: E/StrictMode(661): at android.app.ContextImpl.bindService(ContextImpl.java:1418)
03-20 13:08:16.772: E/StrictMode(661): at android.app.ContextImpl.bindService(ContextImpl.java:1407)
03-20 13:08:16.772: E/StrictMode(661): at android.content.ContextWrapper.bindService(ContextWrapper.java:473)
03-20 13:08:16.772: E/StrictMode(661): at com.android.emailcommon.service.ServiceProxy.setTask(ServiceProxy.java:157)
03-20 13:08:16.772: E/StrictMode(661): at com.android.emailcommon.service.ServiceProxy.setTask(ServiceProxy.java:145)
03-20 13:08:16.772: E/StrictMode(661): at com.android.emailcommon.service.ServiceProxy.test(ServiceProxy.java:191)
03-20 13:08:16.772: E/StrictMode(661): at com.android.exchange.ExchangeService$7.run(ExchangeService.java:1850)
03-20 13:08:16.772: E/StrictMode(661): at com.android.emailcommon.utility.Utility$2.doInBackground(Utility.java:551)
03-20 13:08:16.772: E/StrictMode(661): at com.android.emailcommon.utility.Utility$2.doInBackground(Utility.java:549)
03-20 13:08:16.772: E/StrictMode(661): at android.os.AsyncTask$2.call(AsyncTask.java:287)
03-20 13:08:16.772: E/StrictMode(661): at java.util.concurrent.FutureTask.run(FutureTask.java:234)
03-20 13:08:16.772: E/StrictMode(661): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
03-20 13:08:16.772: E/StrictMode(661): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
03-20 13:08:16.772: E/StrictMode(661): at java.lang.Thread.run(Thread.java:856)
如果需要,我会提供任何解释和代码。我已经处理这个问题一天了。我真的希望有人能帮我解决这个问题。谢谢
最佳答案
感谢所有花时间帮助解决这个问题的人。我发现了我的问题。在 TodayExpenseList.java 中,关于 onPause 生命周期方法。我试图关闭使我的应用程序崩溃的 SQLlite 数据库。在我删除 onPause 方法上的 SQLlite 数据库 close() 方法后,一切都变得很好。
关于在不同的标签上触摸 2 次时发生 Android 崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15525153/
下面的代码旨在在首次打开工作簿时运行。 Sub Auto_Open() Dim LastRow As Integer LastRow = Sheet6.UsedRange.Rows.Count Act
当我尝试操作我的代码时,除了弹出调试错误外,它执行得很好。错误信息在这里。 我的完整代码在这里。 #include using namespace std; class String { publi
The invocation of the constructor on type 'WpfApplication1.MainWindow' that matches the specified bi
我正在使用 BaseAdapter: public class MyAdapter extends BaseAdapter{ private final LayoutInflater mInflate
我想做网页抓取。我写了代码 var connection = require('./mysqlConnection'); var c = new Crawler({ maxConnections
我的系统中发生 Java 堆空间错误。我尝试了很多来自 Stack Overflow 的解决方案,但没有任何效果。当我工作时 当按下 OK 然后 (我的项目没有错误) 我的 eclipse.ini 是
环境: i5 750 DDR3 4GWin7 专业版 x64 sp1 DXSDK 9.0c 2010 年 6 月 GeForce GT240(驱动程序 275.33)512MB MSVC 2008 s
这段代码是我写的。 import socket host = 'localhost' port = 3794 s = socket.socket(socket.AF_INET, socket.SOCK
我正在尝试引用 UTC 时间间隔获取本地日期时间,我正在执行下面的代码。 var dtString =DateTime.UtcNow.ToString(@"yyyy-MM-ddTHH\:mm\:ss
我有一个非常简单的 C# 问题,它从库中加载 Windows WPF 窗口。这是代码: public partial class App : Application { public App(
我目前正在使用带有导航组件的底部导航,它工作正常但是当我们点击导航项 fragment 正在加载然后闪烁正在发生,即使当前选择的项目也会发生闪烁。它在加载 fragment 时发生。我的应用程序屏幕背
我是新来的 kotlin , 当我开始 Null Safety 时,我对下面的情况感到困惑. There's some data inconsistency with regard to initia
我有一个框,其中包含同时发生的两个独立的 css 转换。 当转换发生时,图标下方的标题和段落文本移动位置 参见 JS Fiddle:http://jsfiddle.net/Lsnbpt8r/ 这是我的
在为黑莓 10 构建电话间隙应用程序时,我遇到了异常情况。 [BUILD] Populating application source [BUILD] Parsing config.xml [
这个问题在这里已经有了答案: How to properly stop the Thread in Java? (8 个回答) 3年前关闭。 我看过How to properly stop the T
我试图弄清楚发生 fatal error 时如何刷新页面。基本上我正在访问图像 api 并将图像复制到我的服务器。我还每次都创建照片的缩略图版本。我会每隔一段时间收到一条错误消息,指出我的脚本试图分配
我正在尝试使用断言函数检查元素是否在屏幕上。我在我的测试应用程序 (AndroidDriver) 中使用 Appium 和 Java。我期望的是,如果元素在屏幕上,则返回 1;如果不在屏幕上,则返回
我正在开发图像上传系统。我使用 CommonsMultipartResolver 设置 maxUploadSize。当我尝试上传超过最大尺寸的图像文件时,会发生 MaxUploadSizeExcced
我有以下代码和@ComponentScan(basePackages = "com.project.shopping"),包结构为 com.project.shopping.Controller co
我尝试运行此程序作为测试,但收到错误“发生了 JNI 错误,请检查您的安装并重试”,然后是“发生了 Java 异常”。关于如何解决这个问题有什么想法吗? package java; public cl
我是一名优秀的程序员,十分优秀!