【软件构造】课件精译(二十三)消息传递与图形化用户界面

本文主要是介绍【软件构造】课件精译(二十三)消息传递与图形化用户界面,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、套接字&网络:在两台计算机间传递信息

套接字&网络
网络中的Client/server模式,采用socket作为抽象
网络通信是并发的,需要考虑线程安全问题
需要设计client和server通讯用的线路协议
socket的一些阻塞操作使代码编写更容易,但有可能造成死锁
客户端/服务器设计模式
客户端发起通信,服务器接收、处理、回复,重复此过程,客户端断开连接。服务器可同时处理多个客户端,客户端也可同时连接多个服务器。
客户机和服务器可在不同的计算机上,也可在一台计算机上
IP地址
网络接口由IP地址标识。 IPv4地址是以4个8位部分写入的32位数字
主机名
主机名是可以转换为IP地址的名称
端口
服务器进程绑定到特定的端口,在该端口上进行侦听。客户端必须知道服务器正在侦听哪个端口号。
当客户端连接到服务器时,该连接还使用客户端网络接口上的端口号(通常从不常用端 口中随机选择)
网络套接字
socket(套接字)是用于发送和/或接收数据的网络连接中的端点(socket本质是API,对TCP/IP协议的封装)
服务器进程使用侦听套接字等待来自远程客户端的连接
连接成功的套接字可以发送和接收来自连接另一端的进程的消息,通过本地和远程计算机的IP地址和端口号区分两端计算机
Java中的TCP网络——java.net
(因为课程不作考核,时间原因这部分剩余内容省略,重点是有关多线程的第二部分

二、通过线程进行消息传递

Message passing模型用于在客户端和服务器端的进程间通过sockets传递消息
在同一进程的线程间通过message passing传递消息,比通过锁定机制共享内存更受欢迎
使用同步队列在线程之间传递消息
Java是如何支持消息传递的
BlockingQueue支持在检索元素时等待队列变为非空,在存储元素时等待队列中的空间变得可用
当使用BlockingQueue进行消息传递时,确保使用put和take方法,而不是add和remove方法
生产者 - 消费者设计模式
多个生产者和消费者共享一个同步的队列,都可对其写入和读取,需要同步安全机制
在这里插入图片描述
两种BlockingQueue的实现
ArrayBlockingQueue:定长队列,队列满时put操作会阻塞
LinkedBlockingQueue:可变长度队列
可以保存任意类型的对象
消息采用不可变类型
避免竞争情况和确保原子操作
银行账户的例子
每台自动提款机和每个帐户都是自己的模块,模块通过相互发送消息进行交互。 传入的消息到达队列。
我们设计了取消余额和取款的消息,并表示每台取款机在取款前检查帐户余额以防止透支:
在这里插入图片描述
但它仍然可以交错来自两台取款机的消息,因此它们都被认为可以安全地从一个只有1美元的账户中提取最后一美元。
我们需要选择一个更好的原子操作:撤回 - 如果充足 - 资金将是一个比退出更好的操作。
通过队列实现消息传递
在这里插入图片描述
Stopping
如何关闭Squarer?
在C/S模式下, 可以关闭socket以停止客户端或者服务器继续侦听消息
如果期望服务器和客户端同时关闭,可以退出进程
一种不推荐的策略:使用特殊的消息提示结束(如0,或者null),但是魔数或者null都不是推荐的方式
在这里插入图片描述
interrupt()
interrupted()检测当前线程是否被中断,如果被中断,返回true,并清除中断标志
在这里插入图片描述
消息传递死锁
采用定长队列可以提升性能
为了创建死锁所需的条件,在检查Squarer的任何回复之前,客户端代码将发出N个请求,以获得从1到N的数字的平方。 这是完整的代码:
在这里插入图片描述
随着N变得越来越大(远远大于100),我们的客户在没有阅读任何回复的情况下提出了许多请求。
如果N大于QUEUE_SIZE,则回复队列将填满未读回复。 然后Squarerblockstrying再将一个回复放入该队列,并停止调用请求队列。 客户端可以继续将更多请求放入请求队列,但最多只能达到该队列的大小。
如果有更多的额外请求超出该队列的要求 - 即,当N大于2×QUEUE_SIZE-时,客户端对requests.put()的调用也会阻塞。
Squarer在等待客户端读取一些回复并释放回复队列上的空间,但客户端正在等待Squarer接受一些请求并释放请求队列上的空间。 死锁。
消息传递的线程安全参数
队列本身是线程安全的数据类型
传送的数据是不可变的
生产者和消费者内部的数据对外部是不可见的,仅通过消息通讯
如果消息是可变的,则要确保同一时刻只有一个线程能够访问
防止死锁的方案
一个方案是系统设计层面确保不会出现死锁
另外一个方案是终止阻塞并抛出异常
总结
相比通过锁进行同步,消息传递同步是依靠消息通道进行共享
通过阻塞队列的方式是单进程内部线程间通信的有用方式

三、图形用户界面 (GUI)

(因为课程不作考核,时间原因这部分省略

这篇关于【软件构造】课件精译(二十三)消息传递与图形化用户界面的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/763713

相关文章

软件设计师备考——计算机系统

学习内容源自「软件设计师」 上午题 #1 计算机系统_哔哩哔哩_bilibili 目录 1.1.1 计算机系统硬件基本组成 1.1.2 中央处理单元 1.CPU 的功能 1)运算器 2)控制器 RISC && CISC 流水线控制 存储器  Cache 中断 输入输出IO控制方式 程序查询方式 中断驱动方式 直接存储器方式(DMA)  ​编辑 总线 ​编辑

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

HomeBank:开源免费的个人财务管理软件

在个人财务管理领域,找到一个既免费又开源的解决方案并非易事。HomeBank 正是这样一个项目,它不仅提供了强大的功能,还拥有一个活跃的社区,不断推动其发展和完善。 开源免费:HomeBank 是一个完全开源的项目,用户可以自由地使用、修改和分发。用户友好的界面:提供直观的图形用户界面,使得非技术用户也能轻松上手。数据导入支持:支持从 Quicken、Microsoft Money

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

梳理2024年,螺丝钉们爱用的3款剪辑软件

这年头,视频到处都是,就跟天上的星星一样数不清。不管你是公司里的新面孔,还是职场上的老狐狸,学会怎么剪视频,就好比找到了赢的秘诀。不管是给上司汇报工作,展示你的产品,还是自己搞点小视频记录生活,只要是剪辑得漂亮,肯定能一下子吸引大家的目光,让人记得你。咱们今天就来侃侃现在超火的三款视频剪辑工具,尤其是PR剪辑,你肯定听说过,这货在剪辑界可是大名鼎鼎,用它剪视频,既专业又麻利。 NO1. 福昕轻松

秒变高手:玩转CentOS 7软件更换的方法大全

在 CentOS 7 中更换软件源可以通过以下步骤完成。更换源可以加快软件包的下载速度,特别是当默认源速度较慢时。以下是详细步骤: 前言 为了帮助您解决在使用CentOS 7安装不了软件速度慢的问题,我们推出了这份由浪浪云赞助的教程——“CentOS7如何更换软件源加快下载速度”。 浪浪云,以他们卓越的弹性计算、云存储和网络服务受到广泛好评,他们的支持和帮助使得我们可以将最前沿的技术知识分

excel翻译软件有哪些?如何高效提翻译?

你是否曾在面对满屏的英文Excel表格时感到头疼?项目报告、数据分析、财务报表... 当这些重要的信息被语言壁垒阻挡时,效率和理解度都会大打折扣。别担心,只需3分钟,我将带你轻松解锁excel翻译成中文的秘籍。 无论是职场新人还是老手,这一技巧都将是你的得力助手,让你在信息的海洋中畅游无阻。 方法一:使用同声传译王软件 同声传译王是一款专业的翻译软件,它支持多种语言翻译,可以excel

一款支持同一个屏幕界面同时播放多个视频的视频播放软件

GridPlayer 是一款基于 VLC 的免费开源跨平台多视频同步播放工具,支持在一块屏幕上同时播放多个视频。其主要功能包括: 多视频播放:用户可以在一个窗口中同时播放任意数量的视频,数量仅受硬件性能限制。支持多种格式和流媒体:GridPlayer 支持所有由 VLC 支持的视频格式以及流媒体 URL(如 m3u8 链接)。自定义网格布局:用户可以配置播放器的网格布局,以适应不同的观看需求。硬