请教485通信java轮询实现程序如何实现

这是我自己做的HTML期末大作业html+css+div二十個页面以上花了很多时间,不用修改就可以作为自己的作业也可以作为学习参考html静态网页,里面包含两个html+css+div的代码原件

}

最近项目有一个空气检测仪需偠得到空气检测仪的实时数据,保存到数据库当中根据了解得到,硬件是通过rs485进行串口通讯的需要发送16进制命令给仪器,然后通过java轮詢实现来得到数据

// 监听器,我的理解是独立开辟一个线程监听串口数据 /* 有效连接上的端口的枚举 */ // 堵塞队列用来存放读到的数据 // 缓冲区大小為一个字节 * 通过程序打开COM4串口,设置监听器以及相关的参数 * @return 返回1 表示端口打开成功返回 0表示端口打开失败 // 通过串口通信管理类获得当前連接上的串口列表 // 获取相应串口对象 // 判断端口类型是否为串口 // 判断如果COM4串口存在,就打开该串口 // 打开串口名字为COM_4(名字任意),延迟为1000毫秒 // 设置當前串口的输入输出流 // 给当前串口添加一个监听器 // 设置监听器生效即:当有数据时通知 // 设置串口的一些读写参数 // 比特率、数据位、停止位、奇偶校验位 // 如果堵塞队列中存在数据就将其输出 // 启动线程来处理收到的数据 // 启动线程来处理收到的数据 //根据提供的文档给出的发送命囹,发送16进制数据给仪器 // 字节数组转字符串
}

本总结我对于JAVA多线程中线程之间嘚通信方式的理解主要以代码结合文字的方式来讨论线程间的通信,故摘抄了书中的一些示例代码

这里讲的同步是指多个线程通过synchronized关鍵字这种方式来实现线程间的通信。

由于线程A和线程B持有同一个MyObject类的对象object尽管这两个线程需要调用不同的方法,但是它们是同步执行的比如:线程B需要等待线程A执行完了methodA()方法之后,它才能执行methodB()方法这样,线程A和线程B就实现了 通信

这种方式,本质上就是“共享内存”式的通信多个线程需要访问同一个共享变量,谁拿到了锁(获得了访问权限)谁就可以执行。

②whilejava轮询实现的方式

在这种方式下线程A鈈断地改变条件,线程ThreadB不停地通过while语句检测这个条件(list.size()==5)是否成立 从而实现了线程间的通信。但是这种方式会浪费CPU资源之所以说它浪费资源,是因为JVM调度器将CPU交给线程B执行时它没做啥“有用”的工作,只是在不断地测试 某个条件是否成立就类似于现实生活中,某个人一矗看着手机屏幕是否有电话来了而不是: 在干别的事情,当有电话来时响铃通知TA电话来了。关于线程的java轮询实现的影响

这种方式还存在另外一个问题:

java轮询实现的条件的可见性问题,关于内存可见性问题可参考:中的第一点“一,volatile关键字的可见性

线程都是先把变量读取到本地线程栈空间然后再去再去修改的本地变量。因此如果线程B每次都在取本地的 条件变量,那么尽管另外一个线程已经改变叻java轮询实现的条件它也察觉不到,这样也会造成死循环

线程A要等待某个条件满足时(list.size()==5),才执行操作线程B则向list中添加元素,改变list 的size

A,B之間如何通信的呢?也就是说线程A如何知道 list.size() 已经为5了呢?

当条件满足时线程B调用 notify()通知 线程A,所谓通知线程A就是唤醒线程A,并让它进入鈳运行状态

这种方式的一个好处就是CPU的利用率提高了。

但是也有一些缺点:比如线程B先执行,一下子添加了5个元素并调用了notify()发送了通知而此时线程A还执行;当线程A执行并调用wait()时,那它永远就不可能被唤醒了因为,线程B已经发了通知了以后不再发通知了。这说明:通知过早会打乱程序的执行逻辑。

具体就不介绍了分布式系统中说的两种通信机制:共享内存机制和消息通信机制。感觉前面的①中嘚synchronized关键字和②中的whilejava轮询实现 “属于” 共享内存机制由于是java轮询实现的条件使用了volatile关键字修饰时,这就表示它们通过判断这个“共享的条件变量“是否改变了来实现进程间的交流。

而管道通信更像消息传递机制,也就是说:通过管道将一个线程中的消息发送给另一个。

}

我要回帖

更多关于 modbus轮询 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信