并发处理 优先图和多重图

    • 优先图(Precedence Graph)
    • 视图可串性
    • 多重图(Polygraph)

优先图(Precedence Graph)

优先图用于冲突可串性的判断。

优先图结构:

  • 结点 (Node):事务;
  • 有向边 (Arc): Ti → Tj ,满足 Ti <s Tj;

存在Ti中的操作A1和Tj中的操作A2,满足A1在A2前,并且A1和A2是冲突操作(对同一个元素进行:读写、写读、写写)。

在这里插入图片描述

S 中,

  • 先考虑元素 A,r2(A) w2(A) r3(A) w3(A),很明显,r2(A) 和 w3(A) 、w2(A) 和 w3(A) 是冲突操作,所以画一条有向边,从 T2 指向 T3。
  • 再考虑元素 B,r1(B) w1(B) w2(B),r1(B) 和 w2(B)、w1(B) 和 w2(B) 是冲突操作,所以画一条有向边,从 T1 指向 T2。

在这里插入图片描述

给定一个调度S,构造S的优先图P(S),若P(S)中无环,则S满足冲突可串性。

视图可串性

在这里插入图片描述

在这里插入图片描述

如果按照conflict serializability,S1不可串,实际上S1可串。View serializability 解决了 Conflict serializability 过于严格这一问题。

S1和S2中任何事务的读操作的源都相同。

在这里插入图片描述

区别:

在这里插入图片描述

多重图(Polygraph)

视图可串性判断:多重图 (Polygraph)。
对于调度Z,其Polygraph为LP(Z)。

结构:

  • Node:事务+假想的事务Tb和Tf
  • Arcs:事务(包括Tb和Tf)之间

(1) Tb对所有DB元素执行写操作,构成DB初始状态
(2) Tf读所有DB元素,得到DB终态
(3) 建立Arcs

(3a) If wi(A) ⇒ rj(A) in S, add Ti → Tj(3b) For each wi(A) ⇒ rj(A) do
consider each wk(A): [Tk ≠Tb]
- If Ti ≠Tb ∧ Tj ≠Tf then insert
Tk → Ti some new p
Tj → Tk
- If Ti =Tb ∧ Tj ≠Tf then insert
Tj → Tk
- If Ti ≠Tb ∧ Tj =Tf then insert
Tk → Ti(3c) 对于每一对 Ti → Tj, 选择其中一个,将其在Polygraph中删除,
如果能使Polygraph成为无环图,则调度S是视图可串化的 (V-S)

在这里插入图片描述

在这里插入图片描述

多重图画法步骤

  • 先找出所有的 写->读 操作,注意读的是源头。wb(A)->r1(A),w2(A)->r3(A),w3(A)->rf(A) 这三对如红线所示,注意 wb(A) r3(A) 并不是一对,因为 r3(A) 读的源头是 w2(A) 而不是 wb(A)。
  • 再根据上一步找出的 写->读 操作,对每一个 写->读,找出所有其他事务中的写操作,
    – 如果写是 wb,如 wb(A)->r1(A),那么除了 wb(A) 以外其他对元素 A 的写操作有 w2(A),w3(A),由于 wb(A)->r1(A) 中 T1 是作为 “接收” 的一方,所以接下来由 T1 “发送” 到其他写的事务,即从 T1->T2,T1->T3。如图中绿色线所示。
    – 如果读是 rf,如 w3(A)->rf(A),那么除了 w3(A) 和 wb(A) 以外其他对元素 A 的写操作有 w1(A),w2(A),由于 w3(A)->rf(A) 中 T3 是作为 “发送” 的一方,所以接下来由 T3 “接收” 来自其他写的事务,即从 T1->T3,T2->T3。如图中紫色线所示。
    – 如果写不是 wb,读不是 rf,如 w2(A)->r3(A),那么除了 w2(A) 和 wb(A) 以为其他对元素 A 的写操作有 w1(A),w3(A),由于 w2(A)->r3(A) 中 T2 是 “发送” 的一方,所以接下来由 T2 “接收” 来自其他写的事务,即从 T1->T2,注意标号不为 0,为 1。此外 w2(A)->r3(A) 中 T3 是 “接收” 的一方,所以接下来由 T3 “发送” 到其他写的事务,即从 T3->T1,注意标号不为 0,为 1。如图中黑色线所示。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/867830.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开源全新H5充值系统源码/自定义首页+充值页面/灵活对接上游渠道接口

开源全新H5充值系统源码&#xff0c;系统基于thinkphp框架开发&#xff0c;功能已全完善&#xff0c;可灵活对接其他上游渠道接口&#xff0c;默认对接了大猿人接口&#xff0c;另外可无限制自定义创建充值页面&#xff0c;首页支持后台自定义修改&#xff0c;支持三级分销&…

史上最全的自抗扰控制(ADRC)学习资料

史上最全的自抗扰控制&#xff08;ADRC&#xff09;学习资料 需要的私信我~ 需要的私信我~ 需要的私信我~ ​ 本文将作者近些年来学习ADRC算法的学习资料进行汇总&#xff0c;整理了这一版相对较全的学习资料&#xff0c;包含参考文献以及仿真案例&#xff0c;适合初学者入门&…

6、Redis系统-数据结构-05-整数

五、整数集合&#xff08;Intset&#xff09; 整数集合是 Redis 中 Set 对象的底层实现之一。当一个 Set 对象只包含整数值元素&#xff0c;并且元素数量不大时&#xff0c;就会使用整数集合这个数据结构作为底层实现。整数集合通过紧凑的内存布局和升级机制&#xff0c;实现了…

ECharts 饼图:数据可视化的重要工具

ECharts 饼图&#xff1a;数据可视化的重要工具 引言 在数据分析和可视化的领域&#xff0c;ECharts 是一个广受欢迎的开源库。它由百度团队开发&#xff0c;用于在网页中创建交互式图表。ECharts 提供了多种图表类型&#xff0c;包括柱状图、折线图、散点图等&#xff0c;而…

【学习笔记】Redis学习笔记——第7章 压缩列表

第7章 压缩列表 ZipList&#xff1a;只包含少量小整数与短字符串。 7.1 压缩列表的构成 1>zlbytes&#xff1a;记录整个压缩列表占用内存字节数 2>zltail&#xff1a;尾结点距起始地址多少个字节数 3>zllen&#xff1a;节点数&#xff0c;若节点数超出两个字节所能…

HiAI Foundation开发平台,加速端侧AI应用的智能革命

如果您是一名开发者&#xff0c;正在寻找一种高效、灵活且易于使用的端侧AI开发框架&#xff0c;那么HarmonyOS SDKHiAI Foundation服务&#xff08;HiAI Foundation Kit&#xff09;就是您的理想选择。 作为一款AI开发框架&#xff0c;HiAI Foundation不仅提供强大的NPU计算能…

C语言编程1:变量、常量与输入输出详解

C语言1&#x1f525;&#xff1a; 变量&#xff0c;赋值与初始化&#xff0c;常量&#xff0c;输入与输出 一、变量&#x1f33f; ✨1.1 定义 在C语言中变量是一个用来保存数据的地方。当我们需要在程序里保存数据时就需要用到变量。 ✨1.2 变量名称 变量名称是需要我们自…

直击2024 WAIC现场:关于大模型,热情、焦虑与冷静同在

世博展览馆内人们的热情&#xff0c;与世博中心内参与论坛的人们&#xff0c;心情似乎并不成正比。 展馆内人们看到的大模型加速落地是表象&#xff0c;也是结果&#xff1b;而论坛里的企业家和人工智能学者们则更关注大模型的未来发展方向和商业化进程&#xff0c;以及AI安全…

计算机的错误计算(二十三)

摘要 计算机的错误计算&#xff08;二十二&#xff09;阐明&#xff1a;对于结果应该为 0的算式&#xff0c;即使增加计算精度&#xff0c;也得不出0. 针对 &#xff0c;本节给出一种解决方案。 计算机的错误计算&#xff08;十九&#xff09;展示了计算机对 的错误计算&…

【0基础学爬虫】爬虫框架之 feapder 的使用

前言 大数据时代&#xff0c;各行各业对数据采集的需求日益增多&#xff0c;网络爬虫的运用也更为广泛&#xff0c;越来越多的人开始学习网络爬虫这项技术&#xff0c;K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章&#xff0c;为实现从易到难全方位覆盖&#xff0c;特设【0…

Python遥感开发之时序数据的线性插值

Python遥感开发之时序数据的线性插值 0 历史博客1 实现思路2 代码实现3 效果展示 前言&#xff1a;在遇到空间数据的时候&#xff0c;尤其是哨兵、Landsat或者MODIS数据会出现局部值的空缺&#xff0c;为了解决这些值的空缺&#xff0c;通常采用插值的方法&#xff0c;本博客使…

在Ubuntu 14.04上安装和配置VNC的方法

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 简介 VNC&#xff0c;即“虚拟网络计算”&#xff0c;是一种连接系统&#xff0c;允许您使用键盘和鼠标与远程服务器上的图形桌面环境进…

Python编程学习笔记(1)--- 变量和简单数据类型

1、变量 在学习编程语言之前&#xff0c;所接触的第一个程序&#xff0c;绝大多数都是&#xff1a; print("Hello world!") 接下来尝试使用一个变量。在代码中的开头添加一行代码&#xff0c;并对第二行代码进行修改&#xff0c;如下&#xff1a; message "…

中国星坤X1224系列线对板连接器:小巧稳定,助力物联网终端高效运行

在物联网、电器和消防等领域&#xff0c;终端设备的安全稳定运行至关重要。为了满足这些领域对连接器高可靠性、小巧轻便和耐高温的需求&#xff0c;X1224系列线对板连接器应运而生。这款连接器以其独特的设计和卓越的性能&#xff0c;成为了终端设备中不可或缺的一部分。 一、…

LeetCode415-字符串相加

题目 代码 public String addStrings(String num1, String num2) {if (num1 null) {return num2;}if (num2 null) {return num1;}int min Math.min(num1.length(), num2.length());int abs Math.abs(num1.length() - num2.length());// 0.字符串对齐&#xff08;补0&…

Ubantu22.04 通过FlatPak安装微信

Ubuntu22.04 下使用Flatpak稳定安装微信&#xff01; 国际惯例&#xff0c;废话不多说&#xff0c;先上效果图。为啥使用Flatpak,因为Wechat官方只在FlatPak发布了最新的版本。之前使用了Wine以及Dock安装Wechat,效果都不是很理想&#xff0c;bug很多。所以使用了FlatPak。 Fl…

免费的鼠标连点器电脑版教程!官方正版!专业鼠标连点器用户分享教程!2024最新

电脑技术的不断发展&#xff0c;许多用户在日常工作和娱乐中&#xff0c;需要用到各种辅助工具来提升效率或简化操作&#xff0c;而电脑办公中&#xff0c;鼠标连点器作为一种能够模拟鼠标点击的软件&#xff0c;受到了广大用户的青睐。本文将为大家介绍一款官方正版的免费鼠标…

力扣第134场双周赛压轴题:子数组按位与值为K的数目

题目描述 给你一个整数数组 n u m s nums nums 和一个整数 k k k &#xff0c;请你返回 n u m s nums nums 中有多少个子数组满足&#xff1a;子数组中所有元素按位 A N D AND AND 的结果为 k k k 。 子数组是数组中连续的非空元素序列。 数据范围 1 ≤ n u m s . l e …

解释一下 Redis 的主从复制原理?

Redis 的主从复制是 Redis 实现数据冗余和高可用性的重要机制。它允许创建一个或多个 Redis 服务器&#xff08;从服务器&#xff09;来复制主服务器的数据&#xff0c;从而实现数据的备份和读写分离&#xff0c;提高系统的性能和可靠性。 主从复制的工作原理主要包括以下几个…

使用Java构建一个高性能的消息队列系统

使用Java构建一个高性能的消息队列系统 大家好&#xff0c;我是微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 消息队列系统在现代分布式系统中起着至关重要的作用&#xff0c;它能够提供异步通信、解耦系统组件、缓冲和削…