当前位置: 首页 > news >正文

jQuery小游戏

jQuery小游戏(一)

嘻嘻,今天我们来写个jquery小游戏吧

  1. 首先,我们准备一下写小游戏需要准备的佩饰,如果:图片、音乐、搞怪的小表情

这里我准备了一些游戏中需要涉及到的图片
在这里插入图片描述

  1. 游戏中使用到的方法
  • eval() 函数:用于计算传入字符串形式的 JavaScript 代码并执行它。当调用时不带任何对象前缀时,默认是在全局作用域下运行;而通过 window.eval() 显式指定,则可以在当前窗口上下文中评估表达式

  • window.requestAnimationFrame:这里强调一下为什么使用这个办法,其实setInterval也有定时的作用,但是不同之处在于setInterval需指定时间再执行,window.requestAnimationFrame()则推迟到浏览器下一次重绘时就执行回调。重绘通常是 16ms 执行一次,不过浏览器会自动调节这个速率,比如网页切换到后台 Tab 页时,requestAnimationFrame()会暂停执行。需要注意的是:若是某个函数会影响到网页的布局调整,一般就放在window.requestAnimationFrame()里面执行。 取消操作使用cancelAnimationFrame()方法,下面代码为具体实操:

//requestAnimationFrame效果(function zhouqi(time) {console.log(time,Date.now())render();zhou = requestAnimationFrame(zhouqi);//如果left等于50 停止动画if(left == 50){cancelAnimationFrame(zhou)}})
  • window.cancelAnimationFrame():用于取消先前通过的 window.requestAnimationFrame()方法请求的动画帧回调函数的方法,上面代码也有提及到,在使用 window.requestAnimationFrame()方法创建动画时,通常会把返回的ID存储起来,以便在需要时使用window.cancelAnimationFrame()方法取消动画
  • String.format : Java 中用于格式化字符串的一个方法, String.format 允许你通过占位符来创建一个格式化的字符串。使用 String.format 可以将各种类型的数据(如整数、小数、字符串等)以指定的格式组合成一个字符串
var link, jsGame; (function() {var e = window.eval,t = function(e, t, n) {var r = n || {};if (t) {var i = function() {};i.prototype = t.prototype,e.prototype = new i,e.prototype.constructor = e,e.prototype.superClass = t.prototype,//javascript的superclass继承i = null}for (var s in r) e.prototype[s] = r[s];return r = null, e};window.requestAnimationFrame = function() {return window.requestAnimationFrame || window.webkitRequestAnimationFrame ||   window.mozRequestAnimationFrame || window.oRequestAnimationFrame ||window.msRequestAnimationFrame || window.setTimeout} (),//这段代码是用来兼容不同浏览器的requestAnimationFrame 方法,requestAnimationFrame 用于在下一次浏览器重绘之前执行指定的函数,以实现流畅的动画效果。首先会尝试获取浏览器原生的requestAnimationFrame 方法,如果浏览器不支持,则依次尝试获取其他浏览器的前缀版本,若依旧不支持,则使用setTimeout模拟实现,这样可以确认在不同情况下都能正常运行requestAnimationFrame 方法window.cancelAnimationFrame = function() {//同上面解释类似return window.cancelAnimationFrame || window.webkitCancelAnimationFrame ||window.mozCancelAnimationFrame || window.oCancelAnimationFrame ||window.msCancelAnimationFrame || window.clearTimeout} (),String || (String = {}),String.format || (String.format = function() {if (arguments.length == 0) return null;//当参数个数为0即空数组         //arguments类数组对象var e = arguments[0] || "", t;for (var n = 1, r = arguments.length; n < r; n++) t = new RegExp("\\{" + (n - 1)+"\\}","gm"),e = e.replace(t, arguments[n]);return t = null, e}),
  • Array.prototype : 所有的数组实例都继承于 Array.prototype,和其他构造函数一样,可以通过Arrayprototype属性上的方法来给所有数组实例增加方法
String.getByteLength || (String.getByteLength = function(e) {var t, n = 0, r = e || "", i = r.length;for (t = 0; t < i; t++) r.charCodeAt(t) >= 0 & r.charCodeAt(t) <= 255 ? n += 1 : n += 2;return t = r = i = null, n});if (!Array || !Array.prototype) Array.prototype = {};Array.prototype.indexOfAttr = function(e, t) {var n = (typeof e).toLowerCase(), r = -1;for (var i = 0, s = this.length; i < s; i++) if (n == "string" && this[i][e] == t || n =="number"&& this[i] == e) {r = i;break}
  • canvas: HTML5的新增元素
<canvas id="zhouqi"></canvas> // 如果没有设置宽高,canvas会自动创建一个 300 * 150 的画布(单位默认为px)
canvas.width = 300    // 设置画布宽度
canvas.height = 300   // 设置画布高度
const canvas = document.getElementById('zhouqi')  // 获取画布节点
const ctx = canvas.getContext('2D') // 获取 2D 绘图上下文对象
return n = null, r};var n = {canvas: {id: "linkScreen",defaultId: "linkScreen",defaultFont: "12px Arial",defaultWidth: 240,defaultHeight: 320,defaultColor: "rgb(0, 0, 0)",bgColor: "#000",cavansDoms: [],ctxs: [],device: "",fps: 1,touch: !1,zoom: 1},system: {loadRes: null,pageLoad: null,menu: null,run: null,runFn: function() {},rafRun: null,stop: null,over: null,zone: null,active: null,lastDate: Date.now(),timeout: 30,isPause: !1,gameFlow: -1,loadedImageToGameFlow: -1,zoneArgs: null,activeArgs: null,spendTime: 0,loadResTimer: null,playTimer: null},event: {key: 0,keys: {up: !1,down: !1,left: !1,right: !1,a: !1,b: !1,c: !1,menu: !1,quit: !1},lastKey: {up: !1,down: !1,left: !1,right: !1,a: !1,b: !1,c: !1,menu: !1,quit: !1},pressedKey: {up: !1,down: !1,left: !1,right: !1,a: !1,b: !1,c: !1,menu: !1,quit: !1},keyPressCtrl: {up: !0,down: !0,left: !0,right: !0,a: !0,b: !0,c: !0,menu: !0,quit: !0},keyDownGo: !1,keyUpGo: !1,keyPressedGo: !1,keyDownCallBack: null,keyUpCallBack: null,orientationChange: null,touchStart: null,touchEnd: null,touchMove: null,touchCancel: null,clickCallBack: null,mouseDownCallBack: null,mouseUpCallBack: null,mouseMoveCallBack: null,focused: !1,pageFocusCallBack: null,pageUnFocusCallBack: null,swipeCallBack: null,pageOffX: 0,pageOffY: 0,pageStarOffX: 0,pageStarOffY: 0,swipeDate: null,swipeTimeout: 200,swipeRange: 50},image: {imgs: {},imgObjs: [],initImgs: {},asyncImgObjs: {},imgCount: 0,countLoaded: 0,version: "",inited: !1},audio: {audios: {}},ajax: {xhrObj: null,pool: [],poolLength: 5,date: null,isTimeout: !1,param: {type: "get",data: null,dataType: "json",url: "",xhr: null,timeout: 5e3,before: function(e) {},success: function(e, t) {},error: function(e, t) {},complete: function(e) {}}},}
  • fillStyle: 用于图形内部的颜色
  • fillRect: 用于绘制一个填充的矩形
  • strokeStyle: 用于设置图形轮廓的颜色
  • drawImage: 用于绘制图像
request: {gets: []},buttonLayout: {buttons: [],Button: t(function(e) {this.id = e.id,this.value = e.value,this.x = e.x,this.y = e.y,this.width = e.width,this.height = e.height,this.bgColor = e.bgColor,this.bgStroke = e.bgStroke,this.stroke = e.stroke,this.font = e.font,this.imageId = e.imageId,this.sx = e.sx,this.sy = e.sy,this.color = e.color,this.hx = e.hx,this.hy = e.hy,this.hColor = e.hColor,this.dex = e.dex,this.dey = e.dey,this.deColor = e.deColor,this.hided = e.hided,this.disabled = e.disabled,this.path = e.path,this.hovered = !1,this.repeated = !1,this.pressed = !1,this.released = !1,this.goned = !1,this.cacheId = "buttonLayoutCache_" + this.id,this.setDelay(e.delay).refresh()},null, {refresh: function() {m.canvas.pass(this.cacheId, this.width * 3, this.height),this.imageId == "" ? (this.bgColor != "" && m.canvas.fillStyle(this.bgColor).fillRect(0, 0, this.width, this.height).fillRect(this.width, 0, this.width, this.height).fillRect(this.width * 2, 0, this.width, this.height), this.bgStroke != "" && m.canvas.strokeStyle(this.bgStroke).strokeRect(1, 1, this.width - 2, this.height - 2).strokeRect(this.width + 1, 1, this.width - 2, this.height - 2).strokeRect(this.width * 2 + 1, 1, this.width - 2, this.height - 2)) : m.canvas.drawImage(this.imageId, this.sx, this.sy, this.width, this.height, 0, 0, this.width, this.height).drawImage(this.imageId, this.hx, this.hy, this.width, this.height, this.width, 0, this.width, this.height).drawImage(this.imageId, this.dex, this.dey, this.width * 2, this.height, this.width * 2, 0, this.width, this.height);if (this.value != "") {var e = m.canvas.font(this.font).measureText(this.value),t = this.width - e.width >> 1,n = (this.height - e.height >> 1) + parseInt(this.font) - 2;this.stroke != "" && m.canvas.fillStyle(this.stroke).fillText(this.value, t - 1, n).fillText(this.value, t, n - 1).fillText(this.value, t + 1, n).fillText(this.value, t, n + 1).fillText(this.value, t + this.width - 1, n).fillText(this.value, t + this.width, n - 1).fillText(this.value, t + this.width + 1, n).fillText(this.value, t + this.width, n + 1).fillText(this.value, t + this.width * 2 - 1, n).fillText(this.value, t + this.width * 2, n - 1).fillText(this.value, t + this.width * 2 + 1, n).fillText(this.value, t + this.width * 2, n + 1),m.canvas.fillStyle(this.color).fillText(this.value, t, n).fillStyle(this.hColor).fillText(this.value, t + this.width, n).fillStyle(this.deColor).fillText(this.value, t + this.width * 2, n),e = t = n = null}return m.canvas.pass(),this},show: function() {return this.hided = !1,this},hide: function() {return this.hided = !0,this},disable: function(e) {return this.disabled = e,this},setPath: function(e, t) {return this.setDelay(t).path = e || [],this},endPath: function() {return this.path.length == 0},gone: function(e, t) {return this.setPath(e, t).goned = !0,this},setDelay: function(e) {return this.delay = e || 0,this.delayDate = null,this.delay > 0 && (this.delayDate = Date.now()),this},action: function() {if (this.hided) return this;this.delayDate && Date.now() - this.delayDate >= this.delay && (this.delayDate = null);if (!this.delayDate && this.path.length > 0) {var e = this.path.shift();this.x += e[0],this.y += e[1],e = null}return this},render: function() {return this.hided ? this: (m.canvas.drawCache(this.cacheId, this.hovered ? this.width: this.disabled ? this.width * 2 : 0, 0, this.width, this.height, this.x, this.y, this.width, this.height), this)},disposed: function() {return this}})}},
r = {canvas: {context: {base: 0},graphics: {HCENTER: 1,VCENTER: 2,LEFT: 4,RIGHT: 8,TOP: 16,BOTTOM: 32,ANCHOR_LT: 20,ANCHOR_LV: 6,ANCHOR_LB: 36,ANCHOR_HT: 17,ANCHOR_HV: 3,ANCHOR_HB: 33,ANCHOR_RT: 24,ANCHOR_RV: 10,ANCHOR_RB: 40},trans: {TRANS_MIRROR: 2,TRANS_NONE: 0,TRANS_ROT90: 5,TRANS_ROT180: 3,TRANS_ROT270: 6,TRANS_MIRROR_ROT90: 7,TRANS_MIRROR_ROT180: 1,TRANS_MIRROR_ROT270: 4}},event: {key: {up: 38,down: 40,left: 37,right: 39,a: 90,b: 88,c: 67,menu: 49,quit: 50}},system: {gameFlowType: {menu: 0,run: 1,stop: 2,over: 3,zone: 4,active: 5,loadImage: 6,loadedImage: 7}}},
  • getOffsetX:指 offsetX 属性,是一个只读属性,表示触发事件的位置相对于目标元素内边距边缘 (padding edge) 的 X 坐标位置。如果事件发生在子元素上,则计算的是相对于最近的有定位(position 不为 static)祖先元素的偏移量;该属性属于鼠标事件对象的一部分
  • changedTouches:说到changedTouches,那需要提及的就是移动端滑屏touch事件,刚开始触摸事件touchstarttouchmovetouchend是苹果操作系统Safari浏览器新添加的事件;主要是IOS大多设备没有鼠标及键盘,所以在移动Safari浏览器开发交互性网页时,PC端的鼠标及键盘事件是远远不够的;接下来看看代码中应用到的touch事件
  • touches:当前位于屏幕上的所有手指触摸点的一个列表
  • targetTouches:当前元素对象上所有触摸点的列表
  • changedTouches:涉及当前事件的触摸点的列表
    每个触摸点对应的Touch都有三对重要的属性:(clientX/clientY)、(pageX/pageY)、(screenX/screenY)
    e.changedTouches.length表示获取手指的个数
    e.changedTouches[0].pageX表示获取坐标
i = {getCanvasDom: function() {var e;return function() {return e || (e = m.getDom(n.canvas.defaultId)),e}} (),getOffsetX: function(e) {return e.offsetX || (e.changedTouches && e.changedTouches[0] ? e.changedTouches[0].clientX - i.getCanvasDom().offsetLeft: e.clientX - i.getCanvasDom().offsetLeft) || 0},getOffsetY: function(e) {return e.offsetY || (e.changedTouches && e.changedTouches[0] ? e.changedTouches[0].clientY - i.getCanvasDom().offsetTop: e.clientY - i.getCanvasDom().offsetTop) || 0},

今天的内容有些多,我们先消化这些吧,后面的下一次继续😜😜😜

相关文章:

jQuery小游戏

jQuery小游戏&#xff08;一&#xff09; 嘻嘻&#xff0c;今天我们来写个jquery小游戏吧 首先&#xff0c;我们准备一下写小游戏需要准备的佩饰&#xff0c;如果&#xff1a;图片、音乐、搞怪的小表情 这里我准备了一些游戏中需要涉及到的图片 游戏中使用到的方法 eval() 函…...

Cpp::静态 动态的类型转换全解析(36)

文章目录 前言一、C语言中的类型转换二、为什么C会有四种类型转换&#xff1f;内置类型 -> 自定义类型自定义类型 -> 内置类型自定义类型 -> 自定义类型隐式类型转换的坑 三、C强制类型转换static_castreinterpret_castconst_castdynamic_cast 四、RTTI总结 前言 Hell…...

【PostgreSQL内核学习 —— (WindowAgg(一))】

WindowAgg 窗口函数介绍WindowAgg理论层面源码层面WindowObjectData 结构体WindowStatePerFuncData 结构体WindowStatePerAggData 结构体eval_windowaggregates 函数update_frameheadpos 函数 声明&#xff1a;本文的部分内容参考了他人的文章。在编写过程中&#xff0c;我们尊…...

SQL-leetcode—1158. 市场分析 I

1158. 市场分析 I 表&#xff1a; Users ----------------------- | Column Name | Type | ----------------------- | user_id | int | | join_date | date | | favorite_brand | varchar | ----------------------- user_id 是此表主键&#xff08;具有唯一值的列&#xff…...

opensips中各个模块的解释

模块名称作用说明aaa_diameter提供基于 Diameter 协议的认证、授权和计费服务&#xff0c;适用于移动运营商和ISP的计费系统。aaa_radius提供基于 RADIUS 协议的认证、授权和计费功能&#xff0c;常用于无线网络接入和VPN等场景。auth_jwt用于支持基于 JSON Web Token (JWT) 的…...

【C++初阶】第11课—vector

文章目录 1. 认识vector2. vector的遍历3. vector的构造4. vector常用的接口5. vector的容量6. vector的元素访问7. vector的修改8. vector<vector\<int\>>的使用9. vector的使用10. 模拟实现vector11. 迭代器失效11.1 insert插入数据内部迭代器失效11.2 insert插入…...

SpringBoot开发(二)Spring Boot项目构建、Bootstrap基础知识

1. Spring Boot项目构建 1.1. 简介 基于官方网站https://start.spring.io进行项目的创建. 1.1.1. 简介 Spring Boot是基于Spring4框架开发的全新框架&#xff0c;设计目的是简化搭建及开发过程&#xff0c;并不是对Spring功能上的增强&#xff0c;而是提供了一种快速使用Spr…...

vim如何设置自动缩进

:set autoindent 设置自动缩进 :set noautoindent 取消自动缩进 &#xff08;vim如何使设置自动缩进永久生效&#xff1a;vim如何使相关设置永久生效-CSDN博客&#xff09;...

Jenkins上生成的allure report打不开怎么处理

目录 问题背景&#xff1a; 原因&#xff1a; 解决方案&#xff1a; Jenkins上修改配置 通过Groovy脚本在Script Console中设置和修改系统属性 步骤 验证是否清空成功 进一步的定制 也可以使用Nginx去解决 使用逆向代理服务器Nginx&#xff1a; 通过合理调整CSP配置&a…...

ASP.NET Blazor托管模型有哪些?

今天我们来说说Blazor的三种部署方式&#xff0c;如果大家还不了解Blazor&#xff0c;那么我先简单介绍下Blazor Blazor 是一种 .NET 前端 Web 框架&#xff0c;在单个编程模型中同时支持服务器端呈现和客户端交互性&#xff1a; ● 使用 C# 创建丰富的交互式 UI。 ● 共享使用…...

使用 Confluent Cloud 的 Elasticsearch Connector 部署 Elastic Agent

作者&#xff1a;来自 Elastic Nima Rezainia Confluent Cloud 用户现在可以使用更新后的 Elasticsearch Sink Connector 与 Elastic Agent 和 Elastic Integrations 来实现完全托管且高度可扩展的数据提取架构。 Elastic 和 Confluent 是关键的技术合作伙伴&#xff0c;我们很…...

二叉树的最小深度力扣--111

目录 题目 思路 代码 题目 给定一个二叉树&#xff0c;找出其最小深度。 最小深度是从根节点到最近叶子节点的最短路径上的节点数量。 说明&#xff1a;叶子节点是指没有子节点的节点。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1…...

PySide(PyQT)进行SQLite数据库编辑和前端展示的基本操作

以SQLite数据库为例&#xff0c;学习数据库的基本操作&#xff0c;使用QSql模块查询、编辑数据并在前端展示。 SQLite数据库的基础知识&#xff1a; https://blog.csdn.net/xulibo5828/category_12785993.html?fromshareblogcolumn&sharetypeblogcolumn&sharerId1278…...

ARM64平台Flutter环境搭建

ARM64平台Flutter环境搭建 Flutter简介问题背景搭建步骤1. 安装ARM64 Android Studio2. 安装Oracle的JDK3. 安装 Dart和 Flutter 开发插件4. 安装 Android SDK5. 安装 Flutter SDK6. 同意 Android 条款7. 运行 Flutter 示例项目8. 修正 aapt2 报错9. 修正 CMake 报错10. 修正 N…...

Linux系统编程:进程状态和进程优先级/nice

目录 一,相对于OS的进程状态 1.1运行状态 1.2阻塞状态 1.3挂起状态 二,并发执行与进程切换 2.1,CPU并发执行 2.2进程切换 三,Linux内核管理进程状态的方法 3.1查看进程状态 3.2R状态 3.3S状态 3.4D状态 3.5T状态 3.6X状态 3.7Z状态 3.8孤儿进程 四,进程优先级 …...

【算法】数论基础——唯一分解定理(算术基本定理)python

目录 定义进入正题热身训练实战演练总结 定义 唯一分解定理&#xff1a;也叫做算数基本定理: 任意一个大于1的整数N&#xff0c;都可以唯一分解为若干个质数的乘积 换句话说&#xff0c;任何大于1的整数n可以表示为&#xff1a; 例如&#xff1a; 30 2^1 * 3^1 * 5^1 100 2^2…...

图形化数据报文转换映射工具

目录 概要整体架构流程技术名词解释技术细节小结 概要 在当今数字化时代&#xff0c;数据的处理和分析是企业、科研机构以及各类组织日常运营的核心环节。数据来源广泛&#xff0c;格式多样&#xff0c;常见的数据格式包括XML&#xff08;可扩展标记语言&#xff09;和JSON&a…...

性能优化案例:通过合理设置spark.shuffle.memoryFraction参数的值来优化PySpark程序的性能

在PySpark中&#xff0c;合理调整spark.shuffle.memoryFraction参数可以有效优化Shuffle阶段的性能&#xff0c;尤其是在存在大量磁盘溢出的场景下。 通过合理设置spark.shuffle.memoryFraction并结合其他优化手段&#xff0c;可显著减少Shuffle阶段的磁盘I/O&#xff0c;提升P…...

[C]基础9.深入理解指针(1)

博客主页&#xff1a;算法歌者本篇专栏&#xff1a;[C]您的支持&#xff0c;是我的创作动力。 文章目录 0、总结1、内存和地址1.1 内存1.2 理解编址 2、指针变量和地址2.1 取地址操作符&#xff08;&&#xff09;2.2 指针变量2.3 解引用操作符&#xff08;*&#xff09;2.4…...

网络模型简介:OSI七层模型与TCP/IP模型

计算机网络是现代信息社会的基石&#xff0c;而网络通信的基础在于理解网络模型。网络模型是对通信过程的抽象&#xff0c;它帮助我们理解数据从源到目的地的传输过程。常见的网络模型有 OSI 七层模型 和 TCP/IP 模型&#xff0c;这两种模型在理论和实践中都起着重要作用。 一、…...

第100+35步 ChatGPT学习:时间序列EMD-ARIMA-RF模型 vol. 2

基于Python 3.9版本演示 一、写在前面 上一节&#xff0c;我们学了EMD-ARIMA-RF模型去做预测。 这一节开始&#xff0c;我们尝试使用多项式回归矫正。 二、EMD&RF-ARIMA组合策略 该组合策略主要是将传统的经验模态分解&#xff08;EMD&#xff09;方法和现代的机器学习技…...

Adobe的AI生成3D数字人框架:从自拍到生动的3D化身

一、引言 随着人工智能技术的发展,我们见证了越来越多创新工具的出现,这些工具使得图像处理和视频编辑变得更加智能与高效。Adobe作为全球领先的创意软件公司,最近推出了一项令人瞩目的新技术——一个能够将普通的二维自拍照转换成栩栩如生的三维(3D)数字人的框架。这项技…...

2025美赛数学建模MCM/ICM选题建议与分析,思路+模型+代码

2025美赛数学建模MCM/ICM选题建议与分析,思路模型代码&#xff0c;详细更新见文末名片 一、问题A&#xff1a;测试时间&#xff1a;楼梯的恒定磨损&#xff08;Archaeological Modeling&#xff09; 适合专业&#xff1a;考古学、历史学、数学、机械工程 难度&#xff1a;中等…...

golang中的包管理-上--简介

‌Go语言中的包&#xff08;Package&#xff09;是组织和管理代码的基本单元&#xff0c;通过合理地使用包&#xff0c;可以提高代码的复用性、可维护性和可读性。 包的基本概念和定义 在Go语言中&#xff0c;每个源代码文件都属于一个包。包的声明位于文件的最顶部&#xff…...

深入了解 HTTP 头部中的 Accept-Encoding:gzip、deflate、br、zstd

在现代Web开发中&#xff0c;性能优化是至关重要的一部分。HTTP协议中的Accept-Encoding头部正是为性能提升提供了一个非常有效的方式&#xff0c;它告知服务器客户端能够理解并接收哪些压缩算法的响应内容。在这篇博客中&#xff0c;我们将详细探讨Accept-Encoding头部的作用&…...

QModbusTCPClient 服务器断开引起的程序崩溃

最近使用QModbusTCPClient 与一套设备通信&#xff0c;有一个QTimer频繁的通过读取设备寄存器。程序运行良好&#xff0c;但是有个问题&#xff1a;正常进行中设备断电了&#xff0c;整个程序都会崩溃。解决过程如下&#xff1a; 1.失败方案一 在QModbusTCPClient的errorOccu…...

Unity|小游戏复刻|见缝插针2(C#)

控制针的运动 新建一个Pin脚本 将Pin脚本拖到针Pin的下面 保存代码 using UnityEngine;public class Pin : MonoBehaviour {public float speed 5;private bool isFly false;private bool isReach false;private Transform startPosition;// Start is called once bef…...

数据结构——堆(C语言)

基本概念&#xff1a; 1、完全二叉树&#xff1a;若二叉树的深度为h&#xff0c;则除第h层外&#xff0c;其他层的结点全部达到最大值&#xff0c;且第h层的所有结点都集中在左子树。 2、满二叉树&#xff1a;满二叉树是一种特殊的的完全二叉树&#xff0c;所有层的结点都是最…...

ML基础2-python中的可视化1:matplotlib

承接我的上一篇博客&#xff1a; https://blog.csdn.net/weixin_62528784/article/details/145329298?spm1001.2014.3001.5501 在机器学习的过程中&#xff0c;我们需要掌握大量的Python包&#xff0c;常用的有pandas和numpy这些基本数据管理的包(在后续更新中我会讲解)与mat…...

SpringBoot--基本使用(配置、整合SpringMVC、Druid、Mybatis、基础特性)

这里写目录标题 一.介绍1.为什么依赖不需要写版本&#xff1f;2.启动器(Starter)是何方神圣&#xff1f;3.SpringBootApplication注解的功效&#xff1f;4.启动源码5.如何学好SpringBoot 二.SpringBoot3配置文件2.1属性配置文件使用2.2 YAML配置文件使用2.3 YAML配置文件使用2.…...

9.C++文件与流

C文件与流 在 C 中&#xff0c;文件和流是用于处理输入输出操作的重要概念&#xff0c;以下是关于它们的详细讲解&#xff1a; 流的概念 定义&#xff1a;流是一种抽象概念&#xff0c;它代表了数据的序列。在 C 中&#xff0c;流可以是输入流&#xff08;从外部源如文件或键…...

CSRF 跨站请求伪造漏洞

原理 当一个网站A使用Cookie&#xff0c;存储Session或Token来用于单点登录和权限操作时。浏览器将Cookie存储到浏览器中。当用户在访问另一个网站V时&#xff0c;黑客可以通过伪造表单&#xff0c;向网站A发送修改重要信息(如密码)、支付等操作&#xff0c;浏览器会自动携带C…...

从ABCD谈人工智能对软件开发的影响(2)

接“造词圈子割韭菜”-从ABCD谈人工智能对软件开发的影响&#xff08;1&#xff09; &#xff08;六&#xff09;分步解析之二&#xff1a;组织价值&#xff08;业务用例图&#xff09; 这一步本来建模难度也只有&#xff0c;AI的助力分数可以做到30分。 ★很多领域驱动设计…...

我谈《概率论与数理统计》的知识体系

学习《概率论与数理统计》二十多年后&#xff0c;在廖老师的指导下&#xff0c;才厘清了各章之间的关系。首先&#xff0c;这是两个学科综合的一门课程&#xff0c;这一门课程中还有术语冲突的问题。这一门课程一条线两个分支&#xff0c;脉络很清晰。 概率论与统计学 概率论…...

第 10 课 Python 内置函数

1. 什么是内置函数 Python解释器也是一个程序,它给用户提供了一些常用功能,并给它们起了独一无二的名字,这些常用功能就是内置函数。Python解释器启动以后,内置函数也生效了,可以直接拿来使用。 内置函数是解释器的一部分,它随着解释器的启动而生效;标准库函数是…...

MySQL中的读锁与写锁:概念与作用深度剖析

MySQL中的读锁与写锁&#xff1a;概念与作用深度剖析 在MySQL数据库的并发控制机制中&#xff0c;读锁和写锁起着至关重要的作用。它们是确保数据在多用户环境下能够正确、安全地被访问和修改的关键工具。 一、读锁&#xff08;共享锁&#xff09;概念 读锁&#xff0c;也称为…...

Kotlin Bytedeco OpenCV 图像图像50 仿射变换 图像缩放

Kotlin Bytedeco OpenCV 图像图像50 仿射变换 图像缩放 1 添加依赖2 测试代码3 测试结果 在OpenCV中&#xff0c;仿射变换&#xff08;Affine Transformation&#xff09;和透视变换&#xff08;Perspective Transformation&#xff09;是两种常用的图像几何变换方法。 变换方…...

导出地图为图像文件

使用函数可以将地图或布局视图的内容导出为图像文件. 操作方法: 1.打开目标地图文档 2.导入arcpy.mapping模块 import arcpy.mapping as mapping 3.引用当前活动地图文档,把该引用赋值给变量 mxd mapping.MapDocument() 4.获取地图文档中的数据框列表,查找目标数据框,并…...

【Linux】命令为桥,存在为岸,穿越虚拟世界的哲学之道

文章目录 Linux基础入门&#xff1a;探索操作系统的内核与命令一、Linux背景与发展历史1.1 Linux的起源与发展1.2 Linux与Windows的对比 二、Linux的常用命令2.1 ls命令 - "List"&#xff08;列出文件)2.2 pwd命令 - "Print Working Directory"&#xff08…...

如何在gitee/github上面搭建obsidian的图床

在搭建图床之前我们需要知道图床是一个什么东西,图床顾名思义就是存放图片的地方&#xff0c;那么我们为什么要搭建图床呢&#xff1f;因为我们在写博客的时候&#xff0c;很多同学都是在本地使用typora或者是obsidian进行markdown语法的文章的书写&#xff0c;文件格式通常都是…...

【DIY小记】减肥10kg保持半年的经验分享

作为程序员&#xff0c;脑力劳动者&#xff0c;保持一个健康的身体&#xff0c;是非常重要的。回顾24年自己取得的结果&#xff0c;一个比较亮眼的就是减肥减了10kg&#xff0c;到达了一个比较健康的体重&#xff0c;保持了半年没有反弹&#xff0c;当然到现在也依然在保持。今…...

[STM32 - 野火] - - - 固件库学习笔记 - - -十一.电源管理系统

一、电源管理系统简介 电源管理系统是STM32硬件设计和系统运行的基础&#xff0c;它不仅为芯片本身提供稳定的电源&#xff0c;还通过多种电源管理功能优化功耗、延长电池寿命&#xff0c;并确保系统的可靠性和稳定性。 二、电源监控器 作用&#xff1a;保证STM32芯片工作在…...

C# 探秘:PDFiumCore 开启PDF读取魔法之旅

一、引言 在当今数字化时代&#xff0c;PDF 文件就像一个个神秘的宝盒&#xff0c;里面装满了各种信息。无论是项目文档、学术论文还是产品说明书&#xff0c;PDF 格式凭借其良好的兼容性和稳定性&#xff0c;成为了信息传递的重要载体。想象一下&#xff0c;你接到一个紧急任…...

计算机网络-运输层

重点内容&#xff1a; 运输层 是整个网络体系结构中的关键层次之一。一定要弄清以下一些重要概念&#xff1a; (1) 运输层为相互通信的应用进程提供逻辑通信。 (2) 端口和套接字的意义。 (3) 无连接的 UDP 的特点。 (4) 面向连接的 TCP 的特点。 (5) 在不可靠的网…...

TLF35584 基本介绍

1 概述 1&#xff09;多电压电源芯片&#xff0c;包含6路输出电压。 LDO_Com&#xff1a;低降后调节器 5V/200mA 通信电源。LDO_C &#xff1a;低降后调节器 5V/600mA (TLF35584xxVS1)/3.3 V/600mA (TLF35584xxVS2) uC电源。Volt_Ref &#xff1a;参考电压5.0 V /- 1%/150mA …...

【Python】第四弹---深入理解Python控制流:从顺序到循环的全面解析

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】【MySQL】【Python】 目录 1、顺序语句 2、条件语句 2.1、什么是条件语句 2.2、语法格式 2.3、缩进和代码块 2.4、练习 2.5、空…...

PBFT算法

在我的博客中对于RAFT算法也有详细的介绍&#xff0c;raft算法包含三种角色&#xff0c;分别是&#xff1a;跟随者&#xff08; follower &#xff09;&#xff0c;候选人&#xff08;candidate &#xff09;和领导者&#xff08; leader &#xff09;。集群中的一个节点在某一…...

软件过程模型

软件过程概念 软件生命周期 软件过程 在工作产品构建过程中&#xff0c;所需完成的工作活动&#xff0c;动作和任务的集合。 软件过程模型 软件过程评估 能力成熟度模型&#xff08;CMM&#xff09; 传统软件过程模型 瀑布模型&#xff08;第一个软件过程模型&#xff…...

【Ubuntu】安装SSH启用远程连接

【Ubuntu】安装OpenSSH启用远程连接 零、安装软件 使用如下代码安装OpenSSH服务端&#xff1a; sudo apt install openssh-server壹、启动服务 使用如下代码启动OpenSSH服务端&#xff1a; sudo systemctl start ssh贰、配置SSH&#xff08;可跳过&#xff09; 配置文件 …...

代码随想录算法【Day31】

Day31 56. 合并区间 class Solution { public://按照左边界&#xff0c;从小到大排序static bool cmp(const vector<int>& a, const vector<int>& b){return a[0] < b[0];} ​vector<vector<int>> merge(vector<vector<int>>…...