本文執行個體講述了Android實現TCP用戶端接收資料的方法。分享給大家供大家參考,具體如下:
配合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了。
更多關於Android相關內容感興趣的讀者可查看本站專題:《Android通訊方式總結》、《Android調試技巧與常見問題解決方案匯總》、《Android開發入門與進階教程》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結》、《Android視圖View技巧總結》、《Android布局layout技巧總結》及《Android控制項用法總結》
希望本文所述對大家Android程式設計有所協助。