1.不要新生成线程对View进行更改,UI主线程不允许其他线程操作View
解决办法:
2.Handler 可以产生一个消息队列,将消息传送给UI主线程:主线程自带Looper循环,Looper循环中有MessageQueen,用于将Handler传来的消息顺Looper循环传给UI
可以从自写Thread传msg给UI主线程,也可从主线程传消息给自写Thread,后者需要在自写线程中写Looper
mButton_start_thread= (Button) findViewById(R.id.button_start_thread);
mButton_start_thread.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
new MyThread().start();
}
});
mButton_message= (Button) findViewById(R.id.button_message);
mButton_message.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
handler1.sendEmptyMessage(0);
}
});
}
//分两个Button因为开启MyThread线程后立刻调用handler会报空指针,没有创建好
private Handler handler1;
class MyThread extends Thread{
@Override
public void run() {
Looper.prepare();
handler1=new Handler(){
@Override
public void handleMessage(Message msg) {
Log.d("Message","Activity to Thread");
}
};
Looper.loop();
}
}
3.AsyncTask 写类继承AsyncTask三个方法
class MyAsyncTask extends AsyncTask<String,String,String>{
@Override
protected String doInBackground(String... params) {
while(count<101){
count++;
publishProgress(""+count);
try {
Thread.sleep(200);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
return "下载完成";
}
@Override
protected void onPostExecute(String s) {
super.onPostExecute(s);
mButton_async.setText(s);
}
@Override
protected void onProgressUpdate(String... values) {
super.onProgressUpdate(values);
int count=Integer.parseInt(values[0]);
mProgressBar.setProgress(count);
}
}
然后在主线程中
MyAsyncTask myAsyncTask=new MyAsyncTask();
myAsyncTask.execute("");