这篇文章主要介绍“Android进程间大数据通信LocalSocket怎么创建”,在日常操作中,相信很多人在Android进程间大数据通信LocalSocket怎么创建问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Android进程间大数据通信LocalSocket怎么创建”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!先创建一个LocalServerSocket服务,参数是服务名,注意这个服务名需要唯一,这是两端连接的依据。然后调用accept函数进行等待客户端连接,这个函数是block线程的,所以例子中另起线程。当客户端发起连接后,accept就会返回LocalSocket对象,然后就可以进行传输数据了。首先创建一个LocalSocket对象然后创建一个LocalSocketAddress对象,参数是服务名然后调用connect函数连接到该服务即可。就可以使用这个socket传输数据了。两端的socket对象是一个类,所以两端的发送和接受代码逻辑一致。通过localSocket.inputStream
和localSocket.outputStream
可以获取到输入输出流,通过对流的读写进行数据传输。注意,读写流的时候一定要新开线程处理。因为socket是双向的,所以两端都可以进行收发,即读写发送数据是主动动作,每次发送都需要另开线程,所以如果是多次,我们需要使用一个线程池来进行管理如果需要多次发送数据,可以将其进行封装成一个函数接收数据实际上是进行while循环,循环进行读取数据,这个最好在连接成功后就开始,比如客户端接收数据实际上是一个while循环不停的进行读取,未读到数据就继续循环,读到数据就进行处理再循环,所以这里只另开一个线程即可,不需要线程池。上面只是简单事例,无法传输复杂数据,如果要传输复杂数据,就需要使用DataInputStream
和DataOutputStream
。首先需要定义一套协议。比如定义一个简单的协议:传输的数据分两部分,第一部分是一个int值,表示后面byte数据的长度;第二部分就是byte数据。这样就知道如何进行读写这样就可以传输复杂数据,不会导致数据错乱。上面虽然可以传输复杂数据,但是当我们的数据过大的时候,也会出现问题免费云主机域名。比如传输图片或视频,假设byte数据长度达到1228800,这时我们通过无法读取到所有数据,只能读到一部分。而且会造成后面数据的混乱,因为读取位置错位了。读取的长度大约是65535个字节,这是因为TCP被IP包包着,也会有包大小限制65535。但是注意!写数据的时候如果数据过大就会自动进行分包,但是读数据的时候如果一次读取貌似无法跨包,这样就导致了上面的结果,只能读一个包,后面的就错乱了。那么这种超大数据该如何传输呢,我们用循环将其一点点写入,也一点点读出,并根据结果不断的修正偏移。代码:这样可以避免因为分包而导致读取的长度不匹配的问题到此,关于“Android进程间大数据通信LocalSocket怎么创建”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注百云主机网站,小编会继续努力为大家带来更多实用的文章!
这篇文章主要介绍“微信小程序怎么实现本地缓存数据增删改查功能”,在日常操作中,相信很多人在微信小程序怎么实现本地缓存数据增删改查功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”微信小程序怎么实现本地缓存数据增删改查功能”的疑惑…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。