配合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了。

很久没有登陆自己的账号了,还好自己的账号还在,庆幸之余,发一篇今天的随笔,感谢园子一直保留着这份记忆。

posted on 2014-05-17 23:52  EpicBlue  阅读(20436)  评论(2编辑  收藏  举报