然后点击设置客户端socket端口号和启动客户端socket
11-04 16:03:11.067: V/cheatecore(5774): 获取服务器端的端口号:44034
11-04 16:03:15.575:V/cheatecore-client(5774): client socket begin
11-04 16:03:15.575:V/cheatecore-server(5774): a client socket come here!!!
这个时候出现了a client socket comehere!!!
这条log再次执行刚才的
netstat –an | busybox grep 44034
发现已经变成如下的结果了
已经有随机分配的客户端端口号跟server端建立了链接了
然后再点击获取数据流
reader = new BufferedReader(inputreader);
serveroutwriter = new PrintWriter(newBufferedWriter(new OutputStreamWriter(sk.getOutputStream())),true);
主要获取socket的输入流和输出流,也就是客户端和服务端的tcp链接已经建立起来了,剩下的就是通过流来接收和发送数据了
接着点击
启动服务器socket 接收数据线程
String sReader = reader.readLine();
这条语句就在等着客户端的socket数据过来呢,其中readLine是一个阻塞函数,熟悉C语言的同学,其实这个就是socket 中的 recv函数,阻塞调用了。
因为tcp是全双工的,并且当前状态是长链接,所以服务端可以向客户端发送数据,客户端也可以向服务端发送数据,下一个按钮
服务器端socket发送数据
11-04 16:11:19.810: V/cheatecore-client(5774):客户端接收到服务端的数据:server data
11-04 16:11:19.810:V/cheatecore-server(5774): 服务端接收到客户端的数据:clientdata
这个时候出现的log,客户端在收到服务器的数据以后,也会向服务器端再返回数据,这样就完成了一次交互,但是其实这个时候socket并没有断掉,因为是长链接,可以进行多次发送
最后结束socket
关闭了socket,这个时候再用 netstat –an | busybox grep 44034
这个指令来进行查询,发现如下图:
刚才建立的socket已经释放了,再过一会查询wait超时后也会将端口释放掉了
测试向启动的进程发送数据
11-04 16:15:11.278: E/cheatecore(6163):input target main function!!!!
11-04 16:15:11.278: E/cheatecore(6163):scanf input content is 44034
主要过程是首先启动
/data/data/com.example.sockettest/files/target
这个程序
testprocee =Runtime.getRuntime().exec(cmd);
PrintWriterpoutwriter = newPrintWriter(newBufferedWriter(newOutputStreamWriter(testprocee.getOutputStream())),true);
poutwriter.println(test);
然后发送数据,完成了这次进程间数据的交互,其实这也是进程之间通信的一种方式,和利用socket完成进程之间的通信并列的。