配合log4net使用,用來接收調試信息。因此,此客戶端只管通過TCP接收字符串數據,然后顯示在界面上。
接收TCP數據
try { Socket s = new Socket("192.168.1.5", 8240); InputStream inputStream = s.getInputStream(); DataInputStream input = new DataInputStream(inputStream); byte[] b = new byte[10000]; while(true) { int length = input.read(b); String Msg = new String(b, 0, length, "gb2312"); Log.v("data",Msg); } }catch(Exception ex) { ex.printStackTrace(); }
開線程執行接收操作
但是,如果接收代碼直接放UI按鈕處理事件中,將直接引發NetworkOnMainThreadException,這是因為不能在主線程中執行Socket操作。這里使用AsyncTask開另一個線程執行socket操作。
// Activity按鈕事件中 GetLogTask task = new GetLogTask(); task.execute(null); // Activity類中嵌套類 public class GetLogTask extends AsyncTask<Void,Void,String> { @Override protected String doInBackground(Void...param){ try { Socket s = new Socket("192.168.1.5", 8240); InputStream inputStream = s.getInputStream(); DataInputStream input = new DataInputStream(inputStream); byte[] b = new byte[10000]; while(true) { int length = input.read(b); String Msg = new String(b, 0, length, "gb2312"); Log.v("data",Msg); } }catch(Exception ex) { ex.printStackTrace(); } return ""; } }
AsyncTask與界面線程通信
1、界面需要啟動和暫停TCP接收操作。
界面線程使用AsyncTask.cancel()通知接收線程結束接收操作。
接收線程在doInBackground中調用isCancelled()來檢查是否出現結束接收要求。
2、AsyncTask接收到數據之后,傳遞給界面顯示。
接收線程使用Handler將數據傳遞給界面
使用Handler的話,數據作為“消息”傳遞給界面處理。
Handler包括了處理消息功能和發布消息功能。在這里,處理消息就是在界面上顯示log文本,界面線程來干。發布消息就是將log文本作為參數,調用postmessage功能,接收線程來干。
主線程中的處理消息
Handler handler = new Handler(){ @Override public void handleMessage(Message msg){ text.setText(text.getText().toString()+(String)msg.obj); } };
接收線程中的發布消息
Message msg = new Message(); msg.obj = msgstring; (MainActivity.this).handler.postMessage();
以上就構成了一個簡單,但可用的TCP方式的log接收端。拿個360wifi或者小米wifi,就可以使用手機接收pc應用程序發出來的log了。
很久沒有登陸自己的賬號了,還好自己的賬號還在,慶幸之余,發一篇今天的隨筆,感謝園子一直保留着這份記憶。