性能测试(一)—— 性能测试理论+jmeter的使用

news2025/1/16 20:03:49

1.性能测试介绍

  • 定义:软件的性能是软件的一种非功能特性,它关注的不是软件是否能够完成特定的功能,而是在完成该功能时展示出来的及时性。

  由定义可知性能关注的是软件的非功能特性,所以一般来说性能测试介入的时机是在功能测试完成之后。另外,由定义中的及时性可知性能也是一种指标,可以用时间或其它指标来衡量,通常我们会使用某些工具或手段来检测软件的某些指标是否达到了要求,这就是性能测试。

  • 性能测试定义:指通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试。

2.性能测试目的

  • (1)评估系统的能力:测试中得到的负荷和响应时间数据可以被用于验证所计划的模型的能力,并帮助作出决策;
  • (2)寻找系统瓶颈,进行系统调优;
  • (4)检测软件中的问题;
  • (5)验证稳定性、可靠性;

3.性能测试分类

1.负载测试

通过逐步增加系统负载,测试系统性能的变化,并最终确定在满足系统性能指标的前提下,系统所能承受的最大负载量的测试。如cpu使用率≤80%。

2.压力测试

通过逐步 压力测试是逐步增加负载,使系统某些资源达到饱和甚至失效。什么条件能把系统压崩溃。

3.异常测试

失败测试,是指系统架构方面的测试。如在负载均衡架构中,要测试宕机、节点挂掉等情况系统的反映。

4.并发测试

测试多个用户同时访问同一个应用、同一个模块或者数据记录时是否存在死锁或者其他性能问题,所以几乎所有的性能测试都会涉及一些并发测试。因为并发测试对时间的要求比较苛刻,通常并发用户的模拟都是借助工具,采用多线程或多进程方式来模拟多个虚拟用户的并发操作。通常测试方法设置集合点。

5.容量测试

在一定的软、硬件条件下,在数据库中构造不同数量级的记录数量,通过运行一种或多种业务场景,在一定虚拟用户数量的情况下,获取不同数量级别的性能指标,从而得到数据库能够处理的最大会话能力、最大容量等。系统可处理同时在线的最大用户数,通常和数据库有关。预估未来。

6.可靠性测试

通过给系统加载一定的业务压力的情况下,运行一段时间,检查系统是否稳定。因为运行时间较长,所以通常可以测试出系统是否有内存泄漏的问题。如cpu使用率在80%以上7*24小时运行,系统是否稳定。

7.递增测试

指每隔一定时间段加载不同数目的虚拟用户执行测试点操作,对测试点进行递增用户压力加载测试。如果所有的虚拟用户同时加载,有可能造成AUT的资源突然增大,进而影响后续测试中关心的测试点的数据,所以前面可以稍稍放缓,递增加载虚拟用户。

4.性能测试工作流程

  • 需求分析
  • 性能指标指定
  • 脚本开发
  • 场景设置
  • 监控部署
  • 测试执行
  • 性能分析
  • 性能调优
  • 测试报告

5.系统应用分层架构

  • 显示层 view

    • web
    • android
    • ios
    • H5
  • 逻辑控制层 controller

    • api
  • 数据存储层 model

    • mysql
    • mongodb
    • redis
    • ....

6.性能测试指标定义(掌握)

  • 事务

    事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消。也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做。 事务的结束有两种,当事务中的所以步骤全部成功执行时,事务提交。如果其中一个步骤失败,将发生回滚操作,撤消撤消之前到事务开始时的所以操作。

  • TPS (TransactionPerSecond)

    每秒钟系统能够处理的事务

  • 请求响应时间

    从客户端发起的一个请求开始,到客户端接收到从服务器返回的响应。整个过程所耗费的时间。

  • 事务响应时间

    事务可能由一个或多个请求组成的,事务响应时间主要是针对于用户的角度而言,如转账。

  • 并发定义

    没有严格意义上的并发。并发总有先后,无论差距是1毫秒或者是1微秒,总有一个时间差。所以并发将的是一个时间范围内,比如1秒内。

    比如:

    (一)多用户在系统上进行同一操作,比如双十一,大家都针对同一种商品进行秒杀

    (二)多用户在系统上进行不同操作,比如双十一时,大家针对不同商品进行秒杀,或者是大家有其他不同的操作,比如商品浏览。

  • 并发用户数

    同一单位时间内对系统发起请求的用户数量

  • 吞吐量

    一次性能测试过程中网络上传输的数据量的总和

  • 吞吐率

    单位时间内网络上传输的数据量

    吞吐率=吞吐量/传输时间

  • 点击率

    每秒钟用户向服务器提交的请求数。这个指标是Web应用程序 特有的一个指标,可以想象为每秒钟用户总共在页面上进行多 少次点击动作,但是需要注意的是一次鼠标单击的操作后,客 户端有可能向服务器发送了多次请求。

  • 资源使用率

    对不同系统资源的使用情况,如CPU、内存、io

7.性能测试需求分析

  • 分析目的

    1.明确测试指标

    2.明确测试场景

  • 新系统(新业务)

    1.同行业比较

    2.业务预期 (日活、用户增长...)

  • 老系统

    1.对比以往的用户使用行为以及用户数

8.性能测试工具

  • 常用工具

    LoadRunner

    JMeter

  • 对比

对比纬度LoadRunnerJMeter
量级
易用性
是否开源
语言支持C/java1.5java
是否收费

jmeter的组成

测试计划

  • 线程组

  • 断言

  • 定时器

  • 监听器

  • 配置元件

  • 后置处理器

  • 前置处理器

  • 逻辑控制器

  • Sanmpler 取样器/采样器

      小朋友看到这里你是否有很多问号? 不着急采臣君,就针对每一个在以下的每一篇都做了更详细的介绍,通过小例子就能够清晰明了,开始吧~!

jmeter实现多并发

启动工具:

找到Jmeter的bin目录,运行jmeter.bat,双击启动即可(前提条件:需要配置jdk环境变量)

备注: windows 使用 j meter.bat,Mac或者Liunx系统运行 j meter.sh启动

新建线程组(开启测试的前提):

  • 用于模拟大量用户负载,此元件中可以设置运行的线程数(就是模拟多用户并发等,一线程就是一个用户)

  • 访问路径: 【测试计划】——【线程组】

界面说明:

1、取样器错误后要执行的动作:

继续: 忽略错误,继续执行 (常用)

Start Next Thread Loop: 忽略错误,线程当前循环终止,执行下一个循环。

停止线程: 当前线程停止执行,不影响其他线程正常执行。

停止测试: 整个测试会在所有当前正在执行的线程执行完毕后停止

Stop test now: 整个测试会立即停止执行,当前正在执行的取样器可能会被中断。

这几个配置项控制了“当遇到错误的时候测试的执行策略”是否会继续执行。

2、设置线程数:

线程数也就是并发数,每个线程将会完全独立的运行测试计划,互不干扰。 多个线程用于模仿对服务器的并发访问。

3、设置ramp-up period控制线程执行时间:

ramp-up period用于设置启动所有线程所需要的时间。 如果选择了10个线程,并且ramp-up period是100秒,那么JMeter将使用100秒使10个线程启动并运行。 每个线程将在前一个线程启动后10(100/10)秒后启动。

当这个值设置的很小、线程数又设置的很大时,在刚开始执行时会对服务器产生很大的负荷。

下图的线程配置中,在6秒时间内启动6个线程,每个线程执行2次循环。 那么每个线程之间启动延迟为 1 秒。 如果点击永远那就不停止,跟输入2次是互斥关系。

4、设置循环次数:

该项设置线程组在结束前每个线程循环的次数,如果次数设置为1,那么JMeter在停止前只执行测试计划一次。

5、Delay Thread creation until needed:

 默认情况下,测试开始的时候,所有线程就被创建完了。 如果勾选了此选项,那么线程只会在合适的需要用到的时候创建。

6、线程组调度器设置

 什么时间执行脚本,时间的控制

调度器配置可以更灵活的控制线程组执行的时间

①持续时间(秒):

控制测试执行的持续时间,以秒为单位。

②启动延迟(秒):

控制测试在多久后启动执行,以秒为单位。

③启动时间:

控制测试在某个时间点启动。 但这个配置会被“启动延迟”配置覆盖。

④结束时间:

控制测试执行的结束时间。 但这个配置会被“持续时间”配置覆盖。

如果不想立即执行执行,可以通过调度器控制测试执行的开始时间和结束时间。

当测试开始时,如果设置了调度器,JMeter将等待直到到了开始时间。 在每个周期结束,JMeter将会检查是否到达结束时间,如果达到,停止运行; 否则测试继续运行直到达到了重复限制。

jmeter实现逻辑分支控制

  • 逻辑控制器可以控制采样器(samplers)的执行顺序。 由此可知,控制器需要和采样器一起使用,否则控制器就没有什么意义了。 放在控制器下面的所有的采样器都会当做一个整体,执行时也会一起被执行。

  • 比如在收邮件时,只需要登录一次邮箱就可以查看多封邮件,这个场景在JMeter中只需要使用控制器中的“一次控制器”就可以控制登录的次数。

  • 控制器的访问路径: 【测试计划】——【线程组】—— 【逻辑控制器】

一般情况下我们通常会使用if控制器比较多

    场景: 访问百度,变量为1就可以访问

  1. 新建线程组

  2. 新建用户自定义变量

    3.新建if控制器

    4.新建Http请求

    5.添加结果树并运行

变量为1时:

变量 为2时:

请求失败,不满足逻辑判断条件

jmeter实现配置管理

  • 配置元件为取样器提供预备数据、然后由取样器发出请求; 还可以用来记录服务器的返回数据,比如: Http Cache Manager,自动记录服务器返回的Cache信息。

  • 性能测试中为了模拟大量用户操作往往需要参数化,JMeter中的参数化可以通过配置元件来完成,比如: CSV Data Set Config,可以帮助我们从文件中读取数据。 另外JMeter也提供了从多函数来帮助我们生成动态数据。

  • 配置元件的访问路径: 【测试计划】—— 【配置元件】,详情如下图:

CSV Data Set Config: 保存数据,参数化

DNS Cache Manager: 前端保存图片

FTP: 请求缺省值

HTTP: 协议相关

JDBC Connection Configuration: 连接数据库

案例: Jmeter连接数据库

  1. 添加线程组

  2. 添加 J DBC Conne ction Config uration

    1)Varible Name: 这个是变量的名字,具有唯一性,不能重复

    2)Database URL: jdbc:mysql://数据库地址:数据库端口号/数据库名 

    3)JDBC_Driver_Class:org.gjt.mm.mysql.Driver

    或者 com.mysql.jdbc.Driver   这是固定值

    4) Username: 这个数据库的登录名

    5) Password: 这个是数据库的登录密码

jmeter实现请求预处理

  • 前置处理器在取样器发送请求之前做一些环境或参数的准备工作

  • 例如: 在对数据进行操作前需要建立一个数据库连接,那么前置处理器可以完成这个工作

  • 前置处理器的访问路径: 【测试计划】—— 【前置处理器】

案例: 请求前先先获取参数

  1. 创建线程组

  2. 添加用户参数

  3. 添加BeanShell Sampler

         Beanshell 是一种轻量级的 Java 脚本,纯 Java 编写的,能够动态的执行标准 java 语法及一些扩展脚本语法,类似于 javaScript 和 perl。

    4.查看结果树查看结果

jmeter集合点、定时并发

  • 定时器用于在模拟大量用户在同一时间处理系统业务,起到集合的功能(常用于并发测试),往往实际测试中用的不同,主要是发现性能瓶颈

  • 访问路径: 【测试计划】—— 【线程组】—— 【定时器】

案例:

    访问百度,我期望在我开始执行的时候,停顿2秒

  1. 添加线程组

  2. 添加HTTP请求

  3. 添加定时器

    这里我设置了3秒

  4. 查看结果树

    点击启动

    中间会有3秒的等待时间

    3秒后展示结果

jmeter实现各种请求的发送

  • Sampler【取样器/采样器】用来模拟用户操作,向服务器(被测试系统)发出Http请求、WebService(SOAP/XML-RPC Requests)请求或者Java请求等。

  • 取样器的访问路径: 【测试计划】—— 【线程组】—— 【Sampler】, 常见的取样器如下图:

  • 常用的取样器为 HTTP请求,我们可以把HTTP请求元件看成是一个没有界面的浏览器,它可以发送Http请求,接收服务器的响应数据。

  •     

看到这么多是不是很慌,其实工作中只是用到了几项

  1. BeanShell Sampler 可以理解为 写java代码,引用包(包目录: lib目录下)

    Jmeter导入包:

    导入完毕BeanShell Sampler  中就可以使用jar包了

  2. Debug Sampler 协助调试工作

  3. java请求,如果在Sampler中请求都未满足你特定的需求,使用此请求,自定义编写代码发起请求

jmeter实现关联

    • 后置处理器一般放在取样器之后,用来处理服务器的返回结果。 ( 专门用来对响应数据做处理的元件,JMeter中的关联也是通过后置处理器来完成)

    • 比如一个Web程序在登录后返回一个SessionID,这个SessionID在登录之后的业务过程中会做为验证条件,验证用户是否合法登录了。 我们利用取样器模拟这个请求时就需要带上这个属性,那么如何获取呢?  首先我们要知道这个SessionID从哪里来? ——它是由服务器返回的。 我们需要用什么工具获取它? JMeter提供了元件,比如正则表达式提取器,它支持正则表达式的方式来提取数据。

    • 访问路径: 【测试计划】——【后置处理器】,详情如下图:

案例:

        访问百度,通过正则截“取百度一下,你就知道 ”字符,并通过BeanShell Sampler打印出来

        1.新建线程组

        2.添加HTTP请求

        3.添加正则表达式提取器(具备正则表达式知识基础)

        模板: $1$截取的第一个内容

        

        4.添加 BeanShell Sampler

        5.添加察看结果树

后置处理器很多,有兴趣的可以自行百度查看学习一下。

jmeter实现数据预判试看

    • 【断言】用来验证结果是否正确,类似于LoadRunner中的检查点。 可以帮助我们来判断请求是否成功返回且是否符合要求。 就是用一个预设的结果(值、表达式、时间长短等条件)与实际结果匹配,匹配到则成功,反之失败。

    • 常用的是 响应断言,对于复杂的断言可以通过BeanShell脚本来完成

    • 断言的访问路径: 【测试计划】—— 【断言】

案例: 通过发起http请求百度网址,响应回来内容进行断言

        1.添加线程组

        2.添加HTTP请求,在这个请求中添加响应断言

        3.查看结果树

备注: 断言的话只有在错误的时候会显示断言,如果请求正确,断言的内容一致,不会展示断言结果

jmeter监控数据可视化

    • 监听器收集JMeter的测试结果,JMeter结果收集程序的设计模式就是监听器模式。 JMeter的监听器有两个任务:

    • 1.添加结果监听,并且可以保存测试结果到文件,这些结果数据可以供再次分析使用。

    • 2.展示结果,JMeter可以以表格及图形的形式展示结果,方便测试人员分析测试结果。 在开发测试脚本时,不可避免需要调试,监听器也提供了辅助(比如查看结果树,我们可以在其中看到请求与响应的数据)

    • 监听器的访问路径: 【测试计划】—— 【监听器】,详情如下图:

    • 【取样器】、【断言】、【监听器】组合在一起就可以帮助我们完成发送请求、验证结果及记录结果三项工作。

主要常用为:

察看结果树:

聚合报告:

图形结果:

其他的可自行查看,本次讲解较为工作常用的。

jmeter小助手

函数助手

            

常用的函数助手

    ◆ 随机数(__Random)

 

复制代码

1. 一个范围内的最小值:随机数生成时开始数,也是最小数
2. 一个范围内允许的最大值:随机生成结束数,也是最大数

    ◆ 参数化助手(__CSVRead)

             新建csv格式文件

            假设内容如下:

                    name,sex

                    zhangsan,nan

                    lisi,nv

0代表的第一列

            

改为2显示第二列

    ◆ 计数器(__counter)

             案例: 通过计数器,算打印FLASE和True的累计

            

            

            

            

            

            

            

    ◆ 唯一数(__UUID)

jmeter实现分布式并发

在性能测试过程中,一旦进行高并发操作时就会出现以下尴尬场景,JMeter客户端卡死、请求错误或是超时等,为了解决这一问题,我们需要将一次大的操作分布在多个服务器上,由多个服务器来承担负载压力。

  • master(主压力机)在jmeter.properties中添加remote_hosts

  1. 配置路径: ...\apache-jmeter-5.0\bin\jmeter.properties;

   2. 打开文件编辑: remote_hosts=127.0.0.1 后面增加远程负载机的ip和端口号,如果需要添加多个“, ”用英文逗号分隔

添加一个从机的IP和端口号

remote_hosts=127.0.0.1:1099,127.0.0.1:1100,192.168.0.1:1099

  • Slave(远程负载机)在jmeter.properties中添加server_port

        1. 进入负载机的usr/local/apache-jmeter-5.1.1/bin目录,编辑jmeter.properties文件

            

 
# 每个人安装Jmeter路径可能不同,注意修改路径

vim  usr/local/apache-jmeter-5.1.1/bin

            2. 修改端口号

                找到#server_port=1099,去掉#号,wq保存退出

  备注: 这里的端口号可以自定义,只要与主压力机里面配置的一致即可           

            3. Slave(远程负载机)启动Jmeter-server  

 
# 输入命令:


./jmeter-server -Djava.rmi.server.hostname=192.168.3.130

             如果直接输入./jmeter-server会报如下错误:

    防火墙未关可能引起错误

 
远程启动时一直连接不上负载机

解决办法:
遇到这种情况时,可能存在多种因素,可以参考以下步骤逐一排查
(1)远程负载机的Jmeter-server是否启动成功;

(2)远程负载机是否处于联网状态;

(3)防火墙是否处于关闭状态:

​
centos5/6开启和关闭防火墙命令:

​
开启:
service iptables start

​
关闭:
service iptables stop

​
centos7开启和关闭防火墙命令:
​
开启:
systectl start firewalld.service
​
关闭:
systectl stop firewalld.service
​
此方法为临时关闭,即时生效,重启后失效
​
(4)主压力机和远程负载机的Jmeter版本是否一致;

  • 配置完成后重启主压力机,查看远程启动,可查看到配置的远程负载机IP

  • 验证是否成功

        添加HTTP请求,察看结果树,运行-远程启动-选择从机IP

        结果显示正常说明没有问题,说一点,从机运行的结果中响应数据是空白属于正常现象,如果要查看,可通过日志查看。

  下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

​​编辑资料获取方式 :xiaobei_upup,添加时备注“csdn alex”

我是小北,专注软件测试和测试开发高薪就业和跳槽,有很多就业方案可以分享给你。

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

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

相关文章

便民社区信息小程序源码系统 功能强大 带生活电商+求职招聘功能 带完整的安装代码包以及搭建教程

系统概述 便民社区信息小程序源码系统是一款集多种功能于一身的综合性平台。它旨在为用户提供便捷的生活服务,满足社区居民的各种需求。无论是购物、求职还是获取社区信息,都能在这个平台上得到满足。该系统采用先进的技术架构,确保系统的稳…

sendmail发送邮件配置详解?如何正确设置?

sendmail发送邮件如何保障安全?AokSend有何安全措施? 为了确保sendmail发送邮件的高效性和安全性,正确配置是至关重要的。本文将详细介绍sendmail发送邮件的配置步骤,并探讨如何保障sendmail发送邮件的安全性。同时,我…

排序进阶----插入排序,希尔排序

各位看官们好,接下来鄙人想与大家分享的实现被称为六大排序之一的插入排序。其实关于这六大排序在我们最开始就已经接触过了。我们在最开始学习c语言的时候,我们要学习到其中之一的冒泡排序。虽然现在看起来冒泡排序确实是没有太大的实际效果&#xff0c…

ROS无人机追踪小车项目开发实战 | 第四届中国智能汽车创新大会圆满结束

2024年5月26日,阿木实验室在深圳第四届中国智能汽车创新大会上,开展的《Prometheus开源平台-ROS无人机追踪小车项目开发实战课》圆满结束。 该实战课从初学者的角度出发,通过实践性讲解和开发,使开发者们系统地学习了硬件系统架构…

无需开孔,安全美观:低功耗微波雷达模块开启宠物喂食器新未来

在快节奏的现代生活中,宠物已成为许多家庭的重要成员。然而,忙碌的主人常常为如何确保宠物按时进食而困扰。近年来,智能家居技术飞速发展,宠物喂食器也逐渐智能化,极大地方便了宠物主人。今天,我们要介绍的…

读书 |《人工智能产品经理-AI时代PM修炼手册》

《人工智能产品经理——AI时代PM修炼手册》by张竞宇,read at 2020.04 这是今年准备面试时看的一本书了。全书从宏观层面介绍了AIPM应具备的的视野范围、一套较完备的工作方法论。AI领域的常识、日常工作没有超出这本书的范畴,是一本合格的入门科普书籍。…

Centos安装nvm管理node版本(让安装变得可控又快捷)

Centos安装nvm管理node版本(让安装变得可控又快捷) 没有找到一个对的人,有可能是你没有走对那条路,也有可能是你没有睁开眼睛,而更大的可能是,你根本就没有出发去找。 安装说明 nvm安装目录:/us…

AI 画图真刺激,手把手教你如何用 ComfyUI 来画出刺激的图

目前 AI 绘画领域的产品非常多,比如 Midjourney、Dalle3、Stability AI 等等,这些产品大体上可以分为两类: 模型与产品深度融合:比如 Midjourney、Dalle3 等等。模型与产品分离:比如 SD Web UI、ComfyUI 等等。 对于…

ms sql server 2008数据库跨服务器迁移方法

一、直接拷贝数据法: 1、打开sql server management studio,选中要迁移的数据库; 2、先在源数据库里点 “脱机”,等到脱机成功后,直接到目录里(默认路径是C:\Program Files\Microsoft SQL Server\MSSQL10.MSS…

LabVIEW异步编程概述

LabVIEW异步编程是一种在图形化编程环境中处理并行任务的方法。通过异步执行,可以提高程序的响应速度和资源利用效率,使得多个任务可以独立进行而不互相干扰。 原理 LabVIEW异步编程的核心在于使用异步调用节点(Asynchronous Call By Refer…

AI绘画(Stable Diffusion)喂饭级教程-第2篇(SD大模型详解)

SD大模型的概念及基础知识 先做一个比喻 如果SD是一个画师,那么大模型就是画师的大脑! 就是可惜,这个大脑有点轴,它只能想象出自己喜欢的画面。 比如你用了一个二次元的大脑,它想出来的画面就是这样的: …

嵌入式进阶——EEPROM读写

🎬 秋野酱:《个人主页》 🔥 个人专栏:《Java专栏》《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 设置EEPROM读写String字符串官方示例 EEPROM是一种可擦写可编程只读存储器(Electrically Erasable Programmable Read-…

源达投顾的客户服务质量怎么样?

在金融服务行业中,客户服务质量是衡量一个公司成功与否的关键因素之一。源达投顾作为一家专业的投资顾问机构,其客户服务质量一直备受关注。那么,源达投顾的客户服务质量怎么样? 一、客户满意度调查方法 为了全面、客观地了解源…

SurfaceView与TextureView的绘制渲染

SurfaceView与TextureView的绘制渲染 一.SurfaceView1.SurfaceView的初始化1.1 SurfaceControl的创建1.1.1 BLASTBufferQueue与SurfaceControl的绑定 1.2 Surface初始化 2.SurfaceHolder的回调与绘制2.1 画布的获取2.2 矩形的绘制2.3 绘制的提交 二.TextureView1.TextureView的…

一文搞懂Java8 Lambda表达式、方法引用

Lambda表达式介绍 Java 8的一个大亮点是引入Lambda表达式,使用它设计的代码会更加简洁。通过Lambda表达式,可以替代我们以前经常写的匿名内部类来实现接口。Lambda表达式本质是一个匿名函数; 体验Lambda表达式 我们通过一个小例子来体验下L…

物联网都有什么优缺点?——青创智通

工业物联网平台解决方案 物联网,这个曾经似乎遥不可及的科技概念,如今已逐渐渗透到我们生活的方方面面。从智能家居到智能工业,从智能医疗到智能城市,物联网技术正在改变着我们的世界。 然而,正如任何一项技术一样&a…

代码随想录算法训练营第五十四天||392.判断子序列、115.不同的子序列

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、392.判断子序列 思路 二、115.不同的子序列 思路 一、392.判断子序列 给定字符串 s 和 t ,判断 s 是否为 t 的子序列。 字符串的一个子序列是…

FPGA中的乒乓操作

为什么不直接选用一个缓存更大的FIFO而选用乒乓操作为什么乒乓操作可以实现低速处理高速数据乒乓操作适用哪些场景 一、乒乓操作结构 首先先介绍一下乒乓操作的原理,其结构如下: 输入选择单元负责将数据送到数据缓冲模块,然后输出选择单元负…

51 html网页

上节内容的网页是hello world的字符串,但实际上网页应该是html格式的这种超文本标记语言,这一节完善一下网页的各种格式和内容 分文件 实际服务器中,网页的界面应该单独放一个文件,服务器从文件里读取网页的内容 先创建一个wroo…

有效运营企业内部社区的板块有哪些?

随着企业内部沟通和协作的重要性日益凸显,建立一个高效运营的企业内部社区成为越来越多企业的首要任务。针对不同的需求和目标,将企业内部社区分为多个板块,可以更好地促进员工之间的沟通、协作和共享知识。下面介绍如何从分多个板块创建的角…