- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
?
?
Java多线程技术在网络通信系统中的应用
?
?
盛琳阳盛芳圆
摘要:多线程技术是Java高级程序语言解决并发处理问题的解决方案,被广泛应用于具有网络通信功能的软件开发工作。本文分析了线程之间通信的原理,介绍了Java多线程技术实现网络通信的原理,指出了Java多线程技术实现线程安全及同步控制的有效途径,提出了基于Java多线程技术的网络通信系统实现方法改进方案。
关键词:Java高级程序语言;多线程技术;网络通信系统
:TP311:A:1007-9416(2019)08-0108-01
1线程之间通信的原理
软件程序进行资源分配和调度的基本单位被称为进程,进程中一个单一顺序的控制流被称为线程,线程是操作系统能够进行运算调度的最小单位。进程与线程之间的区别就在于进程有独立的存储空间,而线程之间要共享同一个存储空间。一个软件程序在运行时需要有多个线程同时存在,则称其具有多线程特性。在多线程场景下各线程共享CPU和内存,会出现线程的资源使用和存储空间冲突的情况,如线程同步问题、线程牵制问题等。
多线程技术对线程的管理,就是让线程之间共享资源,通过程序干预来控制线程的执行,在必要时刻还要干扰线程获取资源来实现系统的共享资源异步访问机制。多线程实现了线程的资源异步访问,也实现了线程之间的通信和执行排序任务。
2Java多线程技术实现网络通信的原理
网络通信系统一般分为服务器和客户端两个组件。早期的服务器端口只能和一个客户端进行通信,当前一个通信未完成时后续访问都处于等待状态,只有关闭端口重新连接才能进行新的线程通信。随着程序设计语言的不断发展和网络环境的不断优化,网络通信系统都具备了多服务器和多客户端相互访问的能力。在解决网络通信问题时就需要多线程技术的支持。
Java的多线程技术支持线程共享存储空间的机制,并且实现了不同线程之间的信息同步与交流,即网络通信。Java语言处理多线程问题的步骤如下:(1)对处理多线程的条件指令进行校验判断,只有在校验通过的情况下才可以让后续的线程继续执行;(2)当某一个线程指令完成后,要通知条件指令进行二次校验,满足条件后让其他线程继续执行;(3)执行上述两个步骤,让线程不断循环执行下去,实现了不间断的网络通信功能。
3Java多线程技术实现线程安全及同步控制
多线程编程会遇到最大的挑战就是线程安全和同步控制问题。线程安全是指线程并行执行时出现的数据和执行问题,比如线程A在进行集合的遍历查询,线程B则在进行集合的清空操作,这两个线程A和B如果同时进行会出现问题,谁先执行也会对对方的正常执行造成影响。同步控制是指在线程A操作數据时通知其他线程无法获得当前数据,只有线程A完成后其它线程才可以进行访问。Java多线程技术实现线程安全及同步控制的和新方法有synchronized同步锁、wait/notify等待/通知机制、信号量机制等。(1)synchronized同步锁。Java使用synchronized关键字来实现线程同步锁机制,线程可以使用synchronized来申请资源锁定,别的线程在访问带有synchronized关键字的资源时就会自动进入等待状态。当持有synchronized锁的线程完成操作后,可以释放同步锁让其他线程继续访问系统资源。(2)wait/notify等待/通知机制。在处理线程数量较大,彼此之间频繁通信的多线程场景下,可以使用唤醒等待机制来实现网络通信功能。Java中的wait/notify2个方法就实现了线程的等待通知机制。wait/notify指令要在synchronized同步锁的基础上执行。对于获得synchronized同步锁的线程,如果在执行过程中需要等待,可以调用wait方法来进入堵塞队列,与此同时synchronized锁也会失效,其他线程开始获得同步锁进行处理,处理完成后调用notify方法来归还synchronized同步锁。当堵塞队列中有较多线程排队时,调用了notify方法的线程会随机通知一个等待线程进行激活,也可以调用notifyAll方法来通知所有等待的线程,得到通知的线程会进入就绪队列进行后续处理。
4Java多线程实现通信编程
Socket是Java多线程技术的主要类实现,网络通信编程又称为Socket编程。Socket编程基于TCP网络西医,分别实现服务器和客户端。调用ServerSocket来构建服务器线程,为服务器设置固定的IP和端口号;多个客户端程序可以借助Socket实现与服务器的通信和交互,连接结束后服务器还会创建一个Socket对象来记录该次连接。Java多线程实现通信编程的过程如下:(1)网络通信系统服务器端实现。创建服务对象ServerSocket创建服务器对象,让服务器线程等待客户端请求,
您可能关注的文档
- 取料刮板机软启动故障原因分析和处理毕志俊.docx
- 俯采工作面刮板输送机关键结构研究.docx
- 中学政治课教学中学生优良意志品质培养的路径研究.docx
- 分析配网自动化技术对供电可靠性影响.docx
- 基于物联网的智能停车场设计与研究.docx
- 刍议国有林场政工工作方式的优化与改进.docx
- 以提升获得电力为目标的供电企业精益服务管理实践刘树森.docx
- 公路桥梁的绿色施工技术的研究.docx
- 构筑班级学习场域-促进德育全面发展.docx
- 持续性人文关怀理念在ICU护理中的应用分析.docx
- 英语人教PEP版八年级(上册)Unit4+writing+写作.pptx
- 人美版美术四年级(上册)8 笔的世界 课件 (1).pptx
- 人美版美术七年级(上册)龙的制作.pptx
- 英语人教PEP版六年级(上册)Unit 2 第一课时.pptx
- 数学苏教版三年级(上册)3.3 长方形和正方形周长的计算 苏教版(共12张PPT).pptx
- 音乐人教版八年级(上册)青春舞曲 课件2.pptx
- 音乐人教版四年级(上册) 第一单元 音乐知识 附点四分音符|人教版.pptx
- 英语人教PEP版四年级(上册)Unit 6 Part B let's learn 1.pptx
- 道德与法治人教版二年级(上册)课件-3.11大家排好队部编版(共18张PPT).pptx
- 人美版美术七年级(上册)《黄山天下奇》课件1.pptx
文档评论(0)