Java 使用AsyncTask,但在主线程错误上仍然需要做太多工作
我正在学习一个向远程sql数据库添加数据的教程,我得到了上面的错误,并且在某些情况下出现了“endAllStagingAnimators”错误,应用程序使用AsyncTask,所以为什么它仍然给出上面的错误 主要活动:Java 使用AsyncTask,但在主线程错误上仍然需要做太多工作,java,android,android-asynctask,Java,Android,Android Asynctask,我正在学习一个向远程sql数据库添加数据的教程,我得到了上面的错误,并且在某些情况下出现了“endAllStagingAnimators”错误,应用程序使用AsyncTask,所以为什么它仍然给出上面的错误 主要活动: public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void userReg(View view) {
startActivity(new Intent(this,Register.class));
}
}
AsyncTask类背景任务:
public class BackgroundTask extends AsyncTask{
Context context;
BackgroundTask(Context context) {
this.context= context;
}
@Override
protected void onPreExecute() {
super.onPreExecute();
}
@Override
protected Object doInBackground(Object[] params) {
String url_reg= "http://192.168.1.1/webapp/register.php";
String url_login= "http://192.168.1.1/webapp/login.php";
String method= (String) params[0];
if (method.equals("register")) {
String name= (String) params[1];
String user_name= (String) params[2];
String user_pass= (String) params[3];
try {
URL url= new URL(url_reg);
HttpURLConnection httpURLConnection= (HttpURLConnection) url.openConnection();
httpURLConnection.setRequestMethod("POST");
httpURLConnection.setDoOutput(true);
OutputStream os= httpURLConnection.getOutputStream();
BufferedWriter bufferedWriter= new BufferedWriter(new OutputStreamWriter(os,"UTF-8"));
String Data=(URLEncoder.encode("user", "UTF-8") + "=" + URLEncoder.encode(name, "UTF-8") + "&" +
URLEncoder.encode("user_name", "UTF-8") + "=" + URLEncoder.encode(user_name, "UTF-8") +
URLEncoder.encode("user_pass", "UTF-8") + "=" + URLEncoder.encode(user_pass, "UTF-8"));
bufferedWriter.write(Data);
bufferedWriter.flush();
bufferedWriter.close();
os.close();
InputStream is= httpURLConnection.getInputStream();
is.close();
return "Registration Success";
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
return null;
}
@Override
protected void onProgressUpdate(Object[] values) {
super.onProgressUpdate(values);
}
@Override
protected void onPostExecute(Object o) {
Toast.makeText(context,o.toString(),Toast.LENGTH_LONG);
}
}
注册类别:
public class Register extends Activity {
EditText et_name,et_user_name,et_user_pass;
Button btn_register;
String name,userName,userPass;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.register_layout);
et_name= (EditText) findViewById(R.id.et_regname);
et_user_name= (EditText) findViewById(R.id.et_regusername);
et_user_pass= (EditText) findViewById(R.id.et_regpass);
btn_register= (Button) findViewById(R.id.btn_register);
}
public void userReg(View view) {
name= et_name.getText().toString();
userName= et_user_name.getText().toString();
userPass= et_user_pass.getText().toString();
String method= "register";
BackgroundTask backgroundTask= new BackgroundTask(this);
backgroundTask.execute(method,name,userName,userPass);
finish();
}
}
日志:
12-18 16:35:49.818 1964-1980/hilz.mysqldemo W/EGL_emulation: eglSurfaceAttrib not implemented
12-18 16:35:49.818 1964-1980/hilz.mysqldemo W/OpenGLRenderer: Failed to set EGL_SWAP_BEHAVIOR on surface 0xa502f580, error=EGL_SUCCESS
12-18 16:35:55.058 1964-1964/hilz.mysqldemo I/Choreographer: Skipped 312 frames! The application may be doing too much work on its main thread.
清单文件:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="hilz.mysqldemo" >
<uses-permission android:name="android.permission.INTERNET"/>
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme" >
<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=".Register" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category." />
</intent-filter>
</activity>
</application>
</manifest>
为什么使用finish()销毁de活动;在调用任务之后?如果这样做,可能会出现许多意外错误。为什么要用finish()销毁de-activity;在调用任务之后?如果你这样做,你可能会有很多意想不到的错误。为Harvoc造成的错误道歉,他们认为代码有两个问题,第一个是我使用的网关IP 192.168.1.1,当我很匆忙的时候,它被认为是我的PC IP,第二个是Toast方法,没有显示,所以我看不到数据被插入,你们也没有注意到,但是我的错误本应该检查得更好,Thaks寻求帮助,为Harvoc造成的问题道歉,他们发现代码有两个问题,第一个是我使用的网关IP 192.168.1.1,当我匆忙的时候,它被认为是我的PC IP,第二个是Toast方法,没有显示,所以我看不到数据被插入,你们也没有注意到,但是我的错误本应该检查得更清楚,Thaks for help你在Register
中调用userReg
的地方我已经读过了,而且已经很有趣了这就是为什么我问这个问题,因为我仍然搞不清楚,我是一个beginner@Mohit在我看到的教程中,它似乎起了作用,这有什么不同之处,在其他什么地方应该这样做??使用探查器(例如,Android Studio中的方法跟踪)来确定您在主应用程序线程上花费的时间。此外,考虑使用<代码> StrictMode <代码>,以使它与主应用程序线程上的I/O相关的日志问题。312帧约为5秒;在不将主应用程序线程的控制权返回框架的情况下,识别代码在何处花费了五秒钟应该不会有问题。在何处调用userReg
inRegister
我已经读到了,这是一个有趣的任务,这就是为什么我问这个问题,因为我仍然搞不清楚,我是一个beginner@Mohit在我看到的教程中,它似乎起到了作用,有什么替代方法,还有什么地方应该这样做?使用探查器(例如,Android Studio中的方法跟踪)来确定在主应用程序线程上花费的时间。此外,考虑使用<代码> StrictMode <代码>,以使它与主应用程序线程上的I/O相关的日志问题。312帧约为5秒;在不将主应用程序线程的控制权返回框架的情况下,识别代码在何处花费了五秒钟应该不会有问题。删除了finish方法,仍然跳过了299帧和相同的错误删除了finish方法,仍然跳过了299帧和相同的错误