編輯:關於Android編程
在Android,線程分為有消息循環的線程和沒有消息循環的線程,有消息循環的線程一般都會有一個Looper。我們的主線程(UI線程)就是一個消息循環的線程。針對這種消息循環的機制,我們引入一個新的機制Handler,我們有消息循環,就要往消息循環裡面發送相應的消息,自定義消息一般都會有自己對應的處理,消息的發送和清除,把這些都封裝在Handler裡面,注意Handler只是針對那 些有Looper的線程,不管是UI線程還是子線程,只要你有Looper,我就可以往你的消息隊列裡面添加東西,並做相應的處理。
一個Handler的創建它就會被綁定到這個線程的消息隊列中,如果是在主線程創建的,那就不需要寫代碼來創建消息隊列了,默認的消息隊列會在主線程被創建。但是如果是在子線程的話,就必須在創建Handler之前先初始化線程的消息隊列。
實例如下:
package com.example.android_handle;
import java.io.BufferedInputStream;
import java.io.InputStream;
import java.net.URL;
import java.net.URLConnection;
import org.apache.http.util.ByteArrayBuffer;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.os.Message;
import android.text.method.ScrollingMovementMethod;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
public class MainActivity extends Activity {
private Handler mHandler;
private Button start;
private TextView text;
private int i = 0;
private Handler handler;
private NewThread thread = new NewThread();
private String s = ;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
start = (Button) findViewById(R.id.start);
text = (TextView) findViewById(R.id.text);
text.setMovementMethod(ScrollingMovementMethod.getInstance());
handler = new Handler() {
@Override
public void handleMessage(Message msg) {
// TODO Auto-generated method stub
s = s + msg.obj +
;
text.setText(s);
Message childMsg = mHandler.obtainMessage();
childMsg.obj = mHandler.getLooper().getThread()
.getName()
+ says Hello;
mHandler.sendMessage(childMsg);
}
};
thread.start();
start.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
if (mHandler != null) {
// 發送消息給子線程
Message childMsg = mHandler.obtainMessage();
childMsg.obj = mHandler.getLooper().getThread()
.getName()
+ says Hello;
mHandler.sendMessage(childMsg);
}
}
});
}
private class NewThread extends Thread {
private Looper mLooper;
private String content;
public void run() {
Looper.prepare();
mLooper = Looper.myLooper();
mHandler = new Handler(mLooper) {
@Override
public void handleMessage(Message msg) {
// TODO Auto-generated method stub
try {
sleep(1000);
// URL uri = new URL(http://112.74.78.53/scut-lib/
// + library/hotReading.php);
// URLConnection ucon = uri.openConnection();
// ucon.setConnectTimeout(10000);
// InputStream is = ucon.getInputStream();
// BufferedInputStream bis = new BufferedInputStream(is);
// ByteArrayBuffer baf = new ByteArrayBuffer(100);
// int current = 0;
// while ((current = bis.read()) != -1) {
// baf.append((byte) current);
// }
// content = new String(baf.toByteArray(), UTF-8);
} catch (Exception e) {
// content = e.toString();
}
i++;
Message msg1 = Message.obtain();
msg1.obj = i+;
handler.sendMessage(msg1);
}
};
Looper.loop();
}
}
}
是什麼BroadCastReceiver是四大組件之一,相當於一個全局的監聽器,用於監聽系統全局的廣播。怎麼樣由於BroadCastReceiver是全局監聽器,因此它可
Android對這種方法進行了封裝,我們沒有權限去調用這個方法,所以我們只能通過AIDL,然後利用Java的反射機制去調用系統級的方法。下面上代碼:(注釋比較詳細)/**
本文實例講述了Android編程實現圓角邊框的方法。分享給大家供大家參考,具體如下:設置邊框圓角可以在drawable-mdpi目錄裡定義一個xml:<?x
Activity在窗口和ViewRootImpl創建後會請求WMS創建一個連接,請求WMS為其創建一個WindowState對象用來描述窗口狀態。Activity與WMS