- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试调试我的应用程序,它似乎为 MainActivity 运行了两次 onCreate 方法。
我输入了一个 Log.i() 命令,果然,它在 Logcat 中出现了两次。
这可能是什么原因?
这是我的 onCreate 代码:
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.i(TAG, "Starting..."); // this appear twice in logcat
// Set activity view
setContentView(R.layout.activity_main);
// Initialise buttons
Button loginBtn = (Button) findViewById(R.id.login);
// Initialise text inputs
screen = (EditText)findViewById(R.id.screen);
pw = (EditText)findViewById(R.id.pw);
final SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this);
String storedScreenCode = sharedPreferences.getString("storedScreenCode", null);
String storedScreenPassword = sharedPreferences.getString("storedScreenPassword", null);
domain = sharedPreferences.getString("apiUrl", null);
final String lastUpdated = sharedPreferences.getString("lastUpdated", null);
if(storedScreenCode != null) {
String url = domain + getResources().getString(R.string.api_login_url) + storedScreenCode + "/" + storedScreenPassword;
try {
status = new NetworkChecker(getApplicationContext()).execute().get(4, TimeUnit.SECONDS);
Log.i(TAG, status.toString());
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
} catch (TimeoutException e) {
Toast.makeText(getBaseContext(), e.getMessage(), Toast.LENGTH_LONG).show();
}
if(status) {
try {
String loginResult = new ReadJSONFeedTask().execute(url).get(4, TimeUnit.SECONDS);
JSONObject loginJson = new JSONObject(loginResult);
if(loginJson.getInt("success") == 1) {
Intent i = new Intent(getApplicationContext(), NextActivity.class);
startActivity(i);
} else {
}
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
} catch (JSONException e) {
e.printStackTrace();
} catch (ParseException e) {
e.printStackTrace();
} catch (TimeoutException e) {
e.printStackTrace();
}
}
}
loginBtn.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View view) {
if (isEmpty(screen) && isEmpty(pw)) {
screen.setError("Screen Code is required!");
pw.setError("Password is required!");
} else {
WifiManager wifi = (WifiManager) getSystemService(Context.WIFI_SERVICE);
ConnectivityManager connManager = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo mWifi = connManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI);
if(!wifi.isWifiEnabled()) {
Toast.makeText(getBaseContext(), "Wifi is not enabled.", Toast.LENGTH_LONG).show();
startActivity(new Intent(Settings.ACTION_WIFI_SETTINGS));
} else if(!mWifi.isConnected()) {
Toast.makeText(getBaseContext(), "Wifi is not connected.", Toast.LENGTH_LONG).show();
startActivity(new Intent(Settings.ACTION_WIFI_SETTINGS));
} else {
//String domain = sharedPreferences.getString("apiUrl", null);
String url = domain + getResources().getString(R.string.api_login_url) + screen.getText().toString() + "/" + pw.getText().toString();
Log.i(TAG, "API Login URL: " + url);
try {
status = new NetworkChecker(getApplicationContext()).execute().get();
Log.i(TAG, "Status: " + status);
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
}
if(status) {
try {
String loginResult = new ReadJSONFeedTask().execute(url).get();
JSONObject loginJson = new JSONObject(loginResult);
// check success boolean
if(loginJson.getInt("success") == 1) { // if success equals 1, carry on with activity
Intent i = new Intent(getApplicationContext(), NextActivity.class);
startActivity(i);
} else {
// if success equals 0, show toast
Toast.makeText(getBaseContext(), loginJson.getString("message") , Toast.LENGTH_LONG).show();
}
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
} catch (JSONException e) {
e.printStackTrace();
} catch (ParseException e) {
e.printStackTrace();
}
} else {
Toast.makeText(getBaseContext(), "No Connectivity", Toast.LENGTH_LONG).show();
}
}
}
}
});
}
我把它分解了一下,把它的主要部分放在 onStart() 中。然后我在 onCreate 和 onStart 中放置一条日志消息,设置断点并作为调试运行。 Android Studio 选择了断点,首先是 onCreate 中的日志消息,然后是 onStart 中的日志消息,然后它返回到 onCreate 并再次返回到 onStart。
所以肯定有东西调用了 onCreate 两次(或整个 Activity ?)
最佳答案
在应该使用 this
或 YourActivity.this
的情况下,您可以多次使用 getApplicationContext() 和 getBaseContext()。在某些情况下,这可能会导致内存泄漏。这应该是一个评论,但我没有足够的代表。非常抱歉...
关于java - MainActivity onCreate 运行两次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25889474/
因此,我正在学习 Lynda.com 上关于使用 Google map V2 构建移动应用程序的教程,并且我正在学习一个让您创建 map 应用程序的部分,该应用程序以编程方式查找位置,而不是依赖于se
我有一个 Mainactivity,其中包含一个 Layout,它是 4 个子布局的父级。单击子布局后,我将使用一个新 fragment 替换主布局。但我无法在按下返回按钮后返回 MainActivi
如你所见 this@MainActivity 或 MainActivity@this 在 kotlin 中开始 Activity 时有效。我试图找出答案,但我什么也没找到。谁能知道它的确切区别以及哪个
Solve by using getActivity() 我有这个 MainActivity.java 和 RepeatEntry.java 在我的 MainActivity 中,我有这个代码来实现
我正在尝试将 Google Analytics 集成到我的应用程序中,并遵循来自 here 的教程一切就绪: 我有一个 MainActivity,它扩展了 Activity 并附加了三个 Tab Fr
EditText 对象未创建,为什么? EditText editText=(EditText)findViewById(R.id.edittext); 这适用于扩展 AsyncTask 类的应用程序
所以我正在尝试了解 Android Fragments。如果我将以下代码放入我的 MainActivity 中: public void getMessage(Object obj) { Lo
我试图在我的Android设备上运行我的Android应用程序,但它一直显示我的主活动不存在,尽管我的主活动类在那里。我试图创建一个新的项目,然后复制我以前的代码,它在一段时间内奏效了。但随后它又产生
//主要活动 package com.going.books; import androidx.appcompat.app.AppCompatActivity; import androi
这似乎是一个我不好意思问的基本问题,但我对我的 Fragment 学习曲线感到非常沮丧,以至于我会暴露我的无知。 教科书中的一个例子,它削减了很多角落,使得扩展变得困难,即使它们有效,也没有按钮可以点
我正在将我的启动 Activity 从“MainActivity”更改为“RealMain”我在 list 中声明了这一点,但是 MainActivity 仍然首先出现。有人可以启发我吗?代码来 se
它失败了@ below line - bindService(intent, m_serviceConnection, Context.BIND_AUTO_CREATE); 下面是轨迹.... Act
我的项目在调试状态下正常工作。当我打开MainActivity.java文件时,这在import androidx.annotation.NonNull;上显示了问题 并在下面显示错误。 FAILUR
我在 MainActivity 类中看到了这样的代码: class MainActivity : AppCompatActivity() { private val languages = a
我的问题是关于如何制作启动屏幕,并在 MainActivity 完成渲染时完成启动屏幕,而不是通过设置超时。 我已经搜索过如何制作闪屏并且我已经做到了,但主要是他们使用超时来设置闪屏何时必须关闭/完成
大家好,我正在尝试为我的 Android 手机开发一个手电筒应用程序,但是当我运行它时出现错误。 GUI 有 2 个按钮:1 个用于开灯,另一个用于关灯 这是代码: package com.examp
如何解决这个问题? MainActivity.this is not an enclosing class. 谢谢 public class uploadToServer extends AsyncT
我的 logcat 中出现一些错误,并且我的应用程序无法在我的智能手机上运行...我更改了 list 和 MainActivity 中的一些代码(名为 HomaActivity ) 这是我的 list
我想知道使用单例 MainAcitivity 是否是一个糟糕的设计选择,如下所示: public class MainActivity extends AppCompatActivity ... {
我正在创建一个像 WhatsApp 一样的应用程序,但我遇到了问题。该应用程序应该进入 LoginActivity,但它直接进入 MainActivity,而无需我登录。 我尝试更改 Android
我是一名优秀的程序员,十分优秀!