计算机网络:数据链路层 - 可靠传输协议

计算机网络:数据链路层 - 可靠传输协议

    • 可靠传输概念
    • 停止-等待协议 SW
    • 回退N帧协议 GBN
    • 选择重传协议 SR


可靠传输概念

如下所示,帧在传输过程中受到干扰,产生了误码。接收方的数据链路层,通过真伪中的真检验序列 FCS 字段的值,也就是检错码可以检测出帧中出现了比特差错。那么接下来该如何处理呢?

在这里插入图片描述

这取决于数据链路层向其上层提供的服务类型:

  • 如果提供的是不可靠传输服务,则仅仅丢弃有误码的帧,其他什么也不做。
  • 如果提供的是可靠传输服务,那就还要想办法实现发送端发送什么,接收端就收到什么

一般情况下,有线链路的雾码率比较低,为了减小开销,并不要求数据链路层向上提供可靠传输服务,即使出现了物码可靠传输的问题,由其上层处理。

然而,对于无线链路,由于其容易受到干扰,雾码率比较高,因此要求数据链路层必须向上层提供可靠传输服务。

最后要注意的是:可靠传输服务并不仅局限于数据链路层,其他各层均可选择实现可靠传输服务

接下来本博客将讲解三种可靠传输协议,这三种可靠传输实现机制的基本原理并不仅限于数据链路层,可以应用到计算机网络体系结构的各层协议中。


停止-等待协议 SW

如图所示,收发双方基于互联网进行通信,纵坐标为时间,发送方给接收方发送数据分组:

在这里插入图片描述

接收方收到后对其进行差错检测,若没有误码,则接受该数据分组并给发送方发送确认。分组简称为ACK发送方收到对所发送数据分组的确认分组后才能发送下一个数据分组

假设这个数据分组在传输过程中出现了误码,接收方收到后对其进行差错检测,发现了误码,则丢弃该数据分组,并给发送方发送否认分组,简称为NAK

在这里插入图片描述

发送方收到对所发送数据分组的否认NAK,分组后就知道了之前自己所发送的数据分组出现了差错而被接收方拒绝,于是立刻重传该数据分组。因此发送方每发送完一个数据分组后,并不能立刻将该数据分组从缓存中删除,只有在收到针对该数据分组的确认分组后,才能将其从缓存中删除。

发送方每发送完一个数据分组后,就停止发送下一个数据分组,等待来自接收方的确认分组或否认分组。

  • 若收到确认分组,则可继续发送下一个数据分组
  • 若收到否认分组,则重发之前发送的那个数据分组。

这样就实现了发送方发送什么,接收方最终都能收到什么,也就是所谓的可靠传输。

但实际情况远比我们想象的要复杂,来看这种情况,发送方给接收方发送数据分组,然而该数据分组在传输过程中丢失了。

在这里插入图片描述

需要说明的是,对于数据链路层点对点信道而言,不太容易出现这种情况,但对于多个网络通过多个路由器互联的复杂互联网环境而言,这种情况是会经常出现的。

对于这种情况,接收方既然收不到数据分组,那么也就不会无缘无故的发送确认或否认分组。如果不采取其他措施,发送方就会一直处于等待接收方确认或否认分组的状态。为了解决该问题,可以在发送方发送完一个数据分组时启动一个超时计时器。若到了超时计时器所设置的重传时间,而发送方仍收不到接收方的确认或否认分组,则重传原来的数据分组,这就叫做超时重传。一般可将重传时间选为略大于从发送方到接收方的平均往返时间。

如图所示,发送方超时重传之前所发送的数据分组:

在这里插入图片描述

接收方正确接收重传的数据分组后,给发送方发送确认分组。发送方收到确认分组后发送下一个数据分组。接收方正确接收该数据分组后给发送方发送确认分组。到目前为止貌似基于停止等待使用确认或否人分组,再加上超时重传的手段,就可以实现可靠传输了。

再来看这种情况,既然发送方发送的数据分组可能丢失,那么接收方发送的确认或否认分组就也有可能丢失。例如发送方发送了一个数据分组,接收方正确接收该数据分组后,给发送方发送确认分组,但该确认分组在传输过程中丢失了。这必然会造成发送方对之前所发送数据分组的超时重传:

在这里插入图片描述

假设这个重传的数据分组也正确到达了接收方,那么现在问题来了,接收方如何判断该数据分组是否是一个重复的分组呢?

为了避免分组重复这种传输错误,必须给每个数据分组带上序号。对于停止等待协议,由于每发送一个数据分组就进行停止等待,只要保证每发送一个新的数据分组,其序号与上次发送的数据分组的序号不同就可以了。因此用一个比特来编号就够了,记序号 0 和 1。

这样根据数据分组的序号接收方,就可以判断出该数据分组是否是重复的。接收方丢弃重复的数据分组,并给发送方发送针对该数据分组的确认分组,以免发送方对该数据分组的再次超时重传

在这里插入图片描述

第一次接受方接收到了DATA0,然后往回传递ACK表示接收到了该分组。发送方没有受到ACK,触发超时重传。当接收方第二次接收到DATA0,就知道这和上一次是同一个分组,把它丢弃再重传一次ACK。当发送方收到ACK,就发送和上一次编号不一样的分组DATA1,接收方收到DATA1,发现和上一次不一样,于是正常接收该分组。

我们通过确认分组丢失的情况,引出了给数据分组编号的问题,请大家思考一下,既然数据分组需要编号,那么确认分组是否也需要编号呢?

来看这种情况:
在这里插入图片描述
发送方发送 0 号数据分组,接收方正确接收后给发送方发送确认分组,由于某些原因,该确认分组迟到了,这必然会导致发送方对 0 号数据分组的超时重传。

在这里插入图片描述

在重传的 0 号数据分组的传输过程中,发送方收到了迟到的确认分组,于是发送 1 号数据分组。接收方收到重传的 0 号数据分组后,发现这是一个重复的数据分组,将其丢弃,并针对该数据分组给发送方发送确认分组,以免发送方再次超时重传该数据分组。现在问题来了,我们可以非常清楚的看到,这是一个对 0 号数据分组的重复确认,但是发送方又如何知道这个ACK是 0 号数据的,而不是 1 号数据的呢?

如果不采取其他措施的话,发送方会误认为这是对 1 号数据分组的确认。如果对确认分组也进行编号,就可以使发送方避免这种误判。如图所示:

在这里插入图片描述

该确认分组的序号为0,发送方通过确认分组的序号知道这是一个重复的确认分组,忽略即可。这个过程叫做确认迟到

我们用给确认分组编号的方法解决了确认迟到所导致的重复确认的问题。需要说明的是,对于数据链路层的点对点信道往返时间比较固定,不会出现确认迟到的情况。因此,如果只在数据链路层实现停止等待协议,可以不用给确认分组编号

接下来我们对停止等待协议的一些注意事项进行一下小结:

  • 接收端检测到数据分组有误码时,将其丢弃,并等待发送方的超时重传。
  • 为了让接收方能够判断所收到的数据分组是否是重复的,需要给数据分组编号。由于停止等待协议的停等特性,只需一个比特编号就够了。记序号 0 和一。
  • 为了让发送方能够判断所收到的确认分组是否是重复的,需要给确认分组编号。数据链路层一般不会出现确认分组迟到的情况,因此在数据链路层实现停止-等待协议,可以不用给确认分组编号。

接下来我们来看看停止等待协议的信道利用率,发送方发送完一个数据分组后就停止发送,并等待接收方对该数据分组的确认。当收到确认分组后,可以发送下一个数据分组:

在这里插入图片描述

  • T D T_{D} TD:发送方发送数据分组所耗费的发送时延
  • RTT:收发双方之间的往返时间
  • T A T_{A} TA: 接收方发送确认分组所耗费的发送时延

途中忽略了接收方对数据分组的处理时延以及发送方对确认分组的处理时延。

总时间为: T D T_{D} TD + RTT + T A T_{A} TA,因此信道的利用率 U 可以用下式来计算:

信道利用率  U = T D T D + R T T + T A \text { 信道利用率 } U=\frac{T_{D}}{T_{D}+R T T+T_{A}}  信道利用率 U=TD+RTT+TATD

T A T_{A} TA一般都远小于 T D T_{D} TD可以忽略,当 RTT 远大于 T D T_{D} TD时,信道利用率会非常低。为了克服停止等待协议,信道利用率很低的缺点,就产生了另外两种协议,即后退N帧协议 GBN 和 选择重传协议。


回退N帧协议 GBN

我们刚介绍了停止等待协议,发送方每发送完一个数据分组,就要停止发送,并等待接收方的确认分组。当收到接收方的确认分组后,才能发送下一个数据分组,如此反复进行。可以看出,发送方每发送完一个数据分组,就至少要等待一个收发双方之间的往返时间。当往返时间较大时,例如卫星链路。停止等待协议的信道利用率很低。若出现超时重传,则信道利用率更低。如图所示,如果发送方在收到接收方的确认分组之前,可以连续发送多个数据分组,则可大大提高信道利用率:

在这里插入图片描述

回退N帧协议,该协议在以上传输的基础上,利用发送窗口来限制发送方可连续发送分组的个数。我们来举例说明,假设采用 3 个比特给分组编序号,因此序号的取值范围是 0- 7。如图所示:
在这里插入图片描述

这是收发双方各自的分组序号。当序号增加到7,下一个序号又从 0 开始。

发送方要维持一个发送窗口,序号落在发送窗口内的数据分组可被连续发送,而不必等收到接收方的相应确认分组后再发送:

在这里插入图片描述

发送窗口的尺寸记为 W T W_{T} WT 。对于本例,其取值范围是[0, 7]。本例取 W T W_{T} WT 的值为5。如果 W T W_{T} WT 的值取为 1,则是停止等待协议。如果 W T W_{T} WT 的值超过取值范围的上限,则会造成严重的错误,我们之后会举例详细说明。

序号落在发送窗口内的数据分组可以连续发送,而序号落在发送窗口外的数据分组不允许发送。

接收窗口的尺寸记为 W R W_{R} WR 对于回退N帧协议,其取值只能为 1,这一点与停止等待协议是相同的。如图所示:

在这里插入图片描述
序号落在接收窗口内的这个数据分组允许接收,而序号落在接收窗口外的数据分组不允许接收。

我们首先来看最简单的情况,也就是无差错的情况,发送方将序号落在发送窗口内的 0- 4 号数据分组依次连续发送出去:

在这里插入图片描述

他们经过互联网的传输,正确到达了接收方,也就是没有出现乱序和误码。接收方按序接收,他们每接收一个数据,接收窗口就向前滑动一个位置,并给发送方发送接收分组的确认分组:

在这里插入图片描述

发送方每接收一个确认分组,发送窗口就向前滑动一个位置,这样就有新的序号落入了发送窗口。发送方可以将收到确认的数据分组从缓存中删除了:

在这里插入图片描述

接下来我们来看累积确认的概念。使用回退N帧协议的接收方可以采用累积确认的方式,也就是说接收方不一定要对收到的数据分组逐个发送确认,而是可以在收到几个数据分组后,对按序到达的最后一个数据分组发送确认ACKn ,表示序号为 n 及以前的所有数据分组都已正确接收了

我们来举例说明累计确认:
在这里插入图片描述

发送方将序号落在发送窗口内的 0- 4 号数据分组依次连续发送出去。他们经过互联网的传输,正确到达了接收方,按序接收。

当接收完 0 号和 1 号数据分组后,给发送方发送了一个累计确认ACK 1。当接收完 2- 4 号数据分组后,又给发送方发送了一个累计确认ACK4。假设ACK 1在传输过程中丢失了,而 ACK 4正确到达了发送方:

在这里插入图片描述

发送方接收ACK 4后就知道了序号为 4 及之前的数据分组已被接收方正确接收了,于是将发送窗口向前滑动 5 个位置。这样就有新的序号落入了发送窗口。从本例可以看出,使用累计确认的其中一个优点就是即使确认分组丢失,发送方也可能不必重传。例如本例中aACK 1丢失了,但并没有造成 1 号数据分组的超时重传。使用累计确认还有其他好处,例如可以减小接收方的开销,减少对网络资源的占用等。

接下来我们来看出现差错的情况,发送方将序号落在发送窗口内的这 5 个数据[5,6,7,0,1]分组依次连续发送出去。他们经过互联网的传输到达了接收方,假设他们在传输过程中受到了干扰,其中 5 号数据分组出现了误码:

在这里插入图片描述

接收方通过数据分组中的检错码发现了错误,于是丢弃该数据分组。而==后续到达的这四个数据分组的序号与接收窗口中的序号不匹配,接收方同样也不能接受他们,将他们丢弃:

在这里插入图片描述

然后对之前按序接收的最后一个数据分组进行确认,也就是发送ACK4,每丢弃一个数据分组就发送一个ACK4 

在这里插入图片描述

这四个ACK4经过互联网的传输到达了发送方。发送方之前就接收过ACK4,当收到这些重复的ACK4 时,就知道了之前所发送的数据分组出现了差错于是可以不等超时计时器超时就立刻开始重传,至于收到几个重复确认就立刻重传,由具体实现来决定。

在本例中,尽管序号为 6701 的数据分组之前已经正确的到达接收方,但由于 5 号数据分组误码不被接受,他们也受到牵连而不被接受发送方还要重传这些数据分组,这就是所谓的 go back N,也就是回退N帧。可见当通信线路质量不好时,回退N帧协议的信道利用率并不比停止等待协议高。

为了减少开销,接收方不一定每收到一个按序到达且无误码的数据分组,就给发送方发回一个确认分组,而是可以在连续收到好几个按序到达且无误码的数据分组后,才针对最后一个数据分组发送确认分组,这称为累积确认


选择重传协议 SR

刚刚我们介绍了回退N帧协议。回退N帧协议的接收窗口尺寸 W T W_{T} WT 能等于一,因此接收方只能按序接收正确到达的数据分组。一个数据分组的误码就会导致其后续多个数据分组不能被接收方按序接收而丢弃,尽管他们没有误码。这必然会造成发送方对这些数据分组的超时重传,显然,这是对通信资源的极大浪费。

为了进一步提高性能,可设法只重传出现误码的数据分组。因此,接收窗口的尺寸 W R W_{R} WR不应再等于一,而应大于一,以便接收方先收下失序到达但无误码,并且序号落在接收窗口内的那些数据分组,等到所缺分组收齐后再一并送交上层。这就是本节课所要介绍的选择重传协议。

需要注意的是,选择重传协议,为了使发送方仅重传出现差错的数据,分组接收方不能再采用累积确认,而需要对每个正确接收到的数据分组进行逐一确认

下面我们来举例说明选择重传协议的工作原理。假设采用 3 个比特给分组编序号,因此序号的取值范围是 0- 7。如图所示:

在这里插入图片描述

  • 发送窗口的尺寸 W T W_{T} WT的取值范围是[1,7],本例取 W T W_{T} WT的值为4。序号落在发送窗口内的这 4 个数据分组可以连续发送。而序号落在发送窗口外的数据分组不允许发送
  • 接收窗口的尺寸 W R W_{R} WR的取值一般情况下可与发送窗口的尺寸 W T W_{T} WT的取值相同,在本例中,其值为4。序号落在接收窗口内的这 4 个数据分组允许接收,而序号落在接收窗口外的数据分组不允许接收

发送方将序号落在发送窗口内的这四个数据分组依次连续发送出去。他们经过互联网的传输陆续到达接收方,但其中的 2 号数据分组丢失了:

在这里插入图片描述

只要序号落入接收窗口内且无误码的数据分组,接收方都会接收, 先接受0 号和 1 号数据分组,并发送 0 号和 1 号确认分组,接收窗口向前滑动两个位置:

在这里插入图片描述

这样就有 4 和 5 这两个新的序号落入接收窗口。接收方接收 3 号数据分组并发送 3 号确认分组:

在这里插入图片描述

但接收窗口不能向前滑动,因为 3 号数据分组是未按需到达的数据分组。

发送方每按序收到一个确认分组发送窗口就向前滑动一个位置。发送方接收 0 号和 1 号确认分组,发送窗口向前滑动两个位置,这样就有 4 和 5 这两个新的序号落入发送窗口,发送方将序号落入发送窗口的 4 号和 5 号数据分组发送出去:

在这里插入图片描述

发送方接收 3 号确认分组,但发送窗口不能向前滑动,因为这是一个未按序到达的确认分组。发送方还未收到 3 之前的 2 号确认分组。不过需要记录 3 号数据分组已收到确认,这样该数据分组就不会超时重发

在这里插入图片描述

4 号和 5 号数据分组到达接收方,接收他们并发送 4 号和 5 号确认分组,但接收窗口不能向前滑动,因为他们是未按序到达的数据分组,接收方还未收到他们之前的 2 号数据分组:

在这里插入图片描述

假设在 4 号和 5 号确认分组的传输过程中,发送方针对 2 号数据分组的重传计时器超时了,发送方重传 2 号数据分组:

在这里插入图片描述

4 号和 5 号确认分组陆续到达发送方接收他们,但发送窗口不能向前滑动,因为他们是未按序到达的确认分组,发送方还未收到他们之前的 2 号确认分组,不过需要记录 4 号和 5 号数据。分组已收到确认,这样他们就不会超时重发:

在这里插入图片描述

发送方之前重传的 2 号数据。分组到达接收方,接收方接收该数据分组并发送 2 号确认。分组接受窗口现在可以向前滑动四个位置,这样就有 6701 这四个新的序号落入接收窗口:

在这里插入图片描述

2 号确认分组经过互联网的传输到达发送方接收,该确认分组发送窗口现在可以向前滑动四个位置,这样就有 6701 这四个新的序号落入发送窗口。发送方现在就可以继续将这四个序号的数据分组依次发送出去了:

在这里插入图片描述

可见,选择重传协议是对回退N帧协议的优化,将接收窗口扩大,哪怕数据不是按照顺序发送的,也可以接收。这样就可以避免对一些已经正常传递的数据的重发,提升效率。


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

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

相关文章

ROS 2边学边练(13)-- 创建一个功能包

前言 功能包是啥 简单理解,功能包就是一个文件夹,一个具备一定功能的文件夹,一个有组织有结构的文件夹,一个能方便分享给其他人使用的文件夹,比如我们的小海龟功能包,它就是一个文件夹,名字叫t…

WPS 不登录无法使用基本功能的解决办法

使用wps时,常常有个比较让人烦恼的事,在不登录的情况下,新建或者打开文档时,wps不让你使用其基本的功能,如设置字体等,相关界面变成灰色,这时Wps提示用户登录注册或登录,但我又不想登…

【QT入门】 无边框窗口设计之综合运用,实现WPS的tab页面

往期回顾: 【QT入门】 无边框窗口设计之实现窗口阴影-CSDN博客 【QT入门】 无边框窗口设计之实现圆角窗口-CSDN博客 【QT入门】 无边框窗口设计综合运用之自定义标题栏带圆角阴影的窗口-CSDN博客 【QT入门】 无边框窗口设计之综合运用,实现WPS的tab页面 …

Nexus的docker安装,maven私服

文章目录 前言安装创建文件夹设置文件夹权限docker创建指令制作docker-compose.yaml文件 查看网站访问网页查看密码 前言 nexus作为私服的maven仓库,在企业级应用中,提供了依赖来源的稳定性,为构建庞大的微服务体系,打下基础 安…

算法——分治(快速排序)

T04BF &#x1f44b;专栏: 算法|JAVA|MySQL|C语言 &#x1faf5; 小比特 大梦想 此篇文章与大家分享分治算法关于快速排序的专题 对于快速排序在我个人主页专栏 <排序> 有详细的介绍,此专题对快排进行了优化操作,并介绍了优化后的快排的几种运用 如果有不足的或者错误的请…

【正点原子探索者STM32F4】TFTLCD实验学习记录:FSMC控制 TFTLCD的寄存器配置

FSMC控制 TFTLCD的寄存器配置 异步模式 A控制 TFTLCDFSMC寄存器配置ILI9341电平持续时间要求 参考 异步模式 A控制 TFTLCD LCD以ILI9341为例 FSMC寄存器配置 对于异步突发访问方式&#xff0c; FSMC 主要设置 3 个时间参数&#xff1a;地址建立时间(ADDSET)、 数据 建立时间…

Unity之PUN实现多人联机射击游戏的优化(Section 2)

目录 &#x1f3ae;一、准备工作 &#x1f3ae;二、实现手雷投掷动作 &#x1f3ae;三、手雷投掷同步 &#x1f4a4;3.1 photonView.RPC &#x1f3ae;四、同步手雷伤害 这几周都给我布置任务了&#xff0c;最近可忙。现在终于有机会更新了&#xff0c;也谢谢大家的阅读&a…

JavaSE-11笔记【多线程2(+2024新)】

文章目录 6.线程安全6.1 线程安全问题6.2 线程同步机制6.3 关于线程同步的面试题6.3.1 版本16.3.2 版本26.3.3 版本36.3.4 版本4 7.死锁7.1 多线程卖票问题 8.线程通信8.1 wait()和sleep的区别&#xff1f;8.2 两个线程交替输出8.3 三个线程交替输出8.4 线程通信-生产者和消费者…

Tailwind 4.0 即将到来:前端开发的“速度与激情”

随着前端开发技术的不断进步&#xff0c;我们每天都在寻找更快、更简洁的解决方案来提升我们的开发效率和用户体验。今天&#xff0c;我要为大家介绍一项令人振奋的新技术进展——Tailwind 4.0的来临&#xff01; 对于经常使用Tailwind的朋友们来说&#xff0c;这个消息无疑是激…

阿里云短信服务业务

一、了解阿里云用户权限操作 1.注册账号、实名认证&#xff1b; 2.使用AccessKey 步骤一 点击头像&#xff0c;权限安全的AccessKey 步骤二 设置子用户AccessKey 步骤三 添加用户组和用户 步骤四 添加用户组记得绑定短信服务权限 步骤五 添加用户记得勾选openApi访问 添加…

Educational Codeforces Round 162 (Rated for Div. 2) ----- E. Count Paths --- 题解

E. Count Paths&#xff1a; 题目大意&#xff1a; 思路解析&#xff1a; 根据题目中定义的美丽路径&#xff0c;我们可以发现路径只有两种情况&#xff1a; 当前结点作为起始结点&#xff0c;那我们只需要知道它的子树下有多少个相同颜色的结点&#xff0c;并且相同颜色的结…

使用 HTMX 和 Bun 进行全栈 Web 开发

将 HTMX 放在前端&#xff0c;Bun 放在后端&#xff0c;然后将它们与 Elysia 和 MongoDB 连接起来&#xff0c;形成快速便捷的技术栈&#xff0c;使开发 Web 应用程序变得轻而易举。 Bun 和 HTMX 是目前软件领域最有趣的两个事情。 Bun 是一个速度极快的一体化服务器端 JavaSc…

如何创建一个TCP多人聊天室?

一、什么是TCP&#xff1f; TCP&#xff08;Transmission Control Protocol&#xff09;是一种可靠的 面向连接的协议 &#xff0c;可以保证数据在传输过程中不会丢失、重复或乱序。 利用TCP实现简单聊天程序&#xff0c;需要客户端和服务器端之间建立TCP连接&#xff0c;并通…

MATLAB近红外光谱分析技术应用

郁磊副教授&#xff0c;主要从事MATLAB编程、机器学习与数据挖掘、数据可视化和软件开发、生理系统建模与仿真、生物医学信号处理&#xff0c;具有丰富的实战应用经验&#xff0c;主编《MATLAB智能算法30个案例分析》、《MATLAB神经网络43个案例分析》相关著作。已发表多篇高水…

C# MES通信从入门到精通(8)——C#调用Webservice服务进行数据交互

前言 在上位机开发领域,使用webservice来访问客户的终端Mes系统是一项必备的技能,本文详细介绍了如何在c#中调用webservice服务,不仅介绍了使用添加服务引用直接调用webservice中的方法外还介绍了使用http的post方法调用webservice方法,过程详细且均为实战经验总结,对于初…

港口核心!达梦数据助力上港集团罗泾码头 I-TOS 系统升级改造

港口作为交通运输的枢纽和联通世界的窗口&#xff0c;肩负着带动区域经济发展及服务国际经贸的双重责任。在信息化浪潮推动下&#xff0c;自动化、数字化、智能化成为港口航运业转型发展的关键。 达梦数据积极推进港口数字化转型升级 &#xff0c;助力上港集团罗泾码头实现 I-T…

青蛙过河(二分+前缀和)

题目描述 小青蛙住在一条河边&#xff0c;它想到河对岸的学校去学习。小青蛙打算经过河里的石头跳到对岸。 河里的石头排成了一条直线&#xff0c;小青蛙每次跳跃必须落在一块石头或者岸上。不过&#xff0c;每块石头有一个高度&#xff0c;每次小青蛙从一块石头起跳&#xf…

[问题记录] oracle问题汇总记录

plsql问题 1、oracle-initialization error could not locate OCI.dll 下载plsql客户端后&#xff0c;登录显示如图所示的错误 解决方法&#xff0c;点击下方链接&#xff0c;下载64位客户端 Instant Client for Microsoft Windows (x64) 64-bit (oracle.com) 2、显示中文乱…

【资源分享】最全ChatGPT镜像免梯子

::: block-1 “时问桫椤”是一个致力于为本科生到研究生教育阶段提供帮助的不太正式的公众号。我们旨在在大家感到困惑、痛苦或面临困难时伸出援手。通过总结广大研究生的经验&#xff0c;帮助大家尽早适应研究生生活&#xff0c;尽快了解科研的本质。祝一切顺利&#xff01;—…

leetCode第十题 : 正则表达式匹配 动态规划【10/1000 python】

&#x1f464;作者介绍&#xff1a;10年大厂数据\经营分析经验&#xff0c;现任大厂数据部门负责人。 会一些的技术&#xff1a;数据分析、算法、SQL、大数据相关、python 作者专栏每日更新&#xff1a; LeetCode解锁1000题: 打怪升级之旅 LeetCode解锁1000题: 打怪升级之旅htt…