原型与原型链
建议大家看的时候手动画图!!!这点很重要!!!
原型链在结构上很像链表,每个对象中都保存着一个地址,指向当前对象的原型,可以层层向上查找,起到继承的效果。
原型链:由对象的__proto__属性串联起来直到Object.prototype.__proto__为null的链,就叫原型链。
原型
1、prototype:显式原型
每个函数都有一个prototype(显式原型)属性,都默认指向一个Object对象【全名:Object构造函数的实例对象。这个对象内部有两个默认携带的属性(方法):__proto__、constructor。在被创建时就携带着这两个属性。】
但是有一个对象除外:Object构造函数(又叫Object函数对象)的prototype属性指向 → Object原型对象,又叫Object.prototype
几乎所有的对象都可以看做Object的实例对象,但这个被指向的对象Object原型对象却不能被叫做Object构造函数的实例化对象,原因是:
所有的Object实例对象必须满足一个要求,其内部的__proto__属性要有值,但是Object原型对象是整个原型链的终点,它的__proto__属性为null。
验证这个特殊的对象:
console.log(Object.prototype.__proto__); // null
(1)查看对象的显式原型
Function原型
function Fun() {};
console.log( Fun.prototype );
这里的__proto__
实际上是对象的[[prototype]]
属性的非标准表示。
从上述控制台输出可以看到,里面除了constructor、__proto__之外,没有其他任何属性。
Date原型
Date函数的显式原型:console.log(Date.prototype);
可以看到,Date函数的原型,是一个Object实例对象。但是这个对象身上有很多的属性(方法),这是因为,在Date构造函数中,通过Date.prototype.xxx向它的原型中添加了很多属性。
(2)向构造函数的原型添加属性
例如:向构造函数Fun的原型中添加一个test属性(方法):
let Fun = new Function()
Fun.prototype.test = function(){console.log("test");
}
console.log( Fun.prototype ); // 检验一下是否添加成功
发现构造函数 Fun 的原型中已经多了一个 test 方法。
图2-1
从上图可以看到,红色箭头就是引用,声明函数和变量会在栈中存放引用地址,实际内容存放在堆中。蓝色箭头表明fun的__proto__指向的是Fun的原型对象,紫色箭头表示Fun的原型对象中constructor指向了Fun的构造函数,而绿色箭头表明Fun构造函数的prototype指针指向的就是Fun的原型对象。
再结合代码,Fun被声明创建了红色箭头的引用。fun是Fun的实例对象,也创建了红色箭头的引用,同时new关键字实例化对象会把fun与Fun的原型进行关联,形成了蓝色箭头。然后在Fun.prototype上面新增了test方法。因此fun可以通过__proto__属性找到构造函数中的test方法,从而进行调用。
Fun函数是Object构造函数的实例化对象,引用类型都会继承Object对象的原型(也就是空Object对象)。结合原型链知识,原型对象中会存在一个指针constructor指向对象的构造函数,也就是图中的紫色箭头,而构造函数中会存在一个prototype指针指向对象的原型对象,也就是图中的绿色箭头。
(3)构造函数的prototype属性指向一个空Object对象(Fun.prototype),在这个对象的内部有一个属性:constructor,它指向生成这个空Object对象的构造函数。
根据以上判断,可以理解下面代码:
console.log( Date.prototype.constructor === Date ); // true
console.log( Fun.prototype.constructor === Fun ); // true
(4)所有函数的显式原型属性都指向一个空Object实例对象
根据图2-1我们截取一小部分,从局部来看
虽然每个函数的原型都是一个空Object对象,但这些对象并不是同一个对象。每个构造函数都有自己的空Object对象。这个空Object对象还有一个别名,对于Fun来说,它的原型对象就可以直接叫做Fun.prototype(Fun的显式原型)。
从图上可以看出prototype指针是指向Fun.prototype这个空Object对象的。
总结:构造函数中存在prototype指针指向原型对象(空Object对象),原型对象(空Object对象)中存在constructor指针指向构造函数
我们可以记这个图:
2、__proto__:隐式原型
每个对象都有一个__proto__属性。对象的隐式原型属性的值对应“生成它的构造函数”的显式原型的值,都指向构造函数的原型:空的Object对象。
从上面解释,可以得出,在原型对象中还有一个__proto__属性值,这个值指向的是,当前原型对象被生成的构造函数的prototype,都指向构造函数的原型(空的Object对象)。
这么说可能不好理解,再根据上面的例子,Fun.prototype是Fun的空Object对象,Fun.prototype本身就是对象,既然是对象就会有__proto__属性,而这个__proto__指向的是生成Fun.prototype的构造函数的prototype(原型对象)。相当于这里的Fun构造函数的__proto__属性,指向Fun.prototype。
同理,(生成Fun.prototype对象)的构造函数的__proto__属性,指向(生成Fun.prototype对象).prototype 。
__proto__ → (生成当前对象的原型对象的构造函数的prototype),再结合上面的图,也就是说__proto__ 指向的就是当前对象的原型对象
注意:对比显示原型对象,区别在于,prototype显示原型针对的是函数,而__proto__隐式原型针对的是对象。因为函数本质上就是Object的扩展。(注意联系)
(1)获取对象的隐式原型
let Fun = new Function();
let fun = new Fun();
console.log( fun.__proto__ );
(2)prototype、__proto__本质上都是一个指针,指向了同一片区域 → 构造函数的显式原型(prototype)指向的空Object对象。
按照这种说法,fun对象中会生成一个属性__proto__指向构造函数Fun的原型空Object对象Fun.prototype(这个空Object对象的名字可以直接叫做Fun.prototype)。验证一下这种说法:
let Fun = new Function();
let fun = new Fun();
console.log( Fun.prototype === fun.__proto__ ); //true
思考:构造函数Fun的原型Object是一个对象。每个实例对象都有一个__proto__属性,那么这个空Object对象的原型(Object.prototype)拥有__proto__属性吗?
答案:没错,就是值比较特殊,为null。原型链就是通过隐式原型__proto__向上查找的,Object.prototype是整个原型链的尽头,所以这里自然就是null了,表示原型链的终止。
console.log( Object.prototype.__proto__ ); // null
接着推测,既然所有的函数都有prototype属性,那Object的构造函数有没有这个属性呢?
答案:有。打印Fun.prototype,其实就是打印构造函数Fun内部生成的空Object对象(原型对象),空Object对象中的__proto__属性,就是由Object构造函数中的prototype复制而来。
这个空的Object对象中__proto__属性,指向的又是谁呢?
答案:空的Object对象中的__proto__属性,指向的就是Object原型对象。所以Object构造函数的prototype属性,指向的也是这个Object原型对象。
let Fun = new Function(); console.log( Fun.prototype.__proto__ ); // Fun.prototype对应的就是这个空Object对象 // 等价于 console.log(Object.prototype) --> 打印 Object 原型对象
从上述的打印可以知道,为什么我们随便创建一个函数,这个函数和它的实例对象都可以使用toString()方法。因为本身Object原型中存在该方法,每个引用对象都会在构造函数中生成这个空Object对象(原型对象)。
每个对象都有__proto__属性,Object原型对象就没有该属性吗?
答案:有,但这个属性值为null。这就是整个原型链的尽头。
总结:每个构造函数中都有一个prototype属性,指向它的原型对象,这个原型对象内部默认是空的。每个实例对象都有一个__proto__属性,指向生成它的构造函数的原型(空Object对象)。每个构造函数的原型(空Object对象)都有一个constructor属性来执行构造函数。
prototype和__proto__创建时间
就构造函数Fun而言,函数Fun的prototype属性在定义这个构造函数的时候就创建出来了;
对于实例对象fun来说,__proto__则是在通过new创建对象的时候才添加的。在实例化一个对象的时候,还做了一件事:this.__proto__ = Fun.prototype,将构造函数的prototype属性赋值给实例对象的__proto__属性。(看到上面的三角图了吗?这样是不更好理解了。就是图中__proto__指向)
往下推理,在创建Fun构造函数的时候,必然还做了一件事:this.prototype = { }【也可以写成:this.prototype = new Object()】,为Fun构造函数创建一个空Object对象。
原型链
看看原型链的经典图解,看起来很复杂,但要求每个前端程序员都能自己画出来。
由于上述代码和图不好看,且不好理解,我们用原型三角图的形式表示,如下:
对画原型图做一个总结:
- 所有的“ 构造函数 ”都有一个 prototype 属性指向其原型:“ 空 Object 对象 ”。
- 所有的“ 实例对象 ”都有一个 __proto__ 属性,指向其构造函数的原型“ 空 Object 对象 ”。
- 所有“ 空Object对象 ”都有一个 constructor 属性,指向创建它的“ 构造函数 ”。
- 每个构造函数的原型“ 空Object对象 ”也是个对象,它们均是由“Object构造函数”实例化而来,因此它们的 __proto__ 均指向 Object 构造函数的原型:“ Object.prototype ”。
- 所有的“ 构造函数 ”(包括Function自身)均是由“ 构造函数 Function ”实例化而来,因此每个构造函数都有一个 __proto__ 属性,指向 Function 的原型 “ Function.prototype ”。(如下图2-2-1)
- “ Object.prototype ”作为整个原型链的终点,其 __proto__ 为 null。
图2-2-1
JS引擎在加载页面的时候,首先会把一些内置的函数加载出来,这其中就包括 Object 构造函数【除 Object 构造函数的原型之外,所有其它构造函数的原型空 Object 对象都是它的实例。】、Object 原型对象。Object 构造函数是一个全局对象,在栈内存中有一个变量名 Object,它内部存储的就是这个全局 Object 构造函数的地址。
1. 原型链查找:
在调用一个方法时,如果对象自身找不到,则通过__proto__属性,沿着原型链不断向上查找,最终会来到Object原型对象,看Object原型对象上是否有此方法,有的话就会调用这个方法,像toString()、hasOwnProperty()、valueOf()等方法就是一层一层向上查找,最终Object原型对象上找到了该方法。假如在Object原型对象上找不到该方法,就会打印undefined。
原型链查找属性例子:
fun.test1():test1在Fun构造函数中被添加,因此实例化对象fun就拥有了该方法,调用test1的时候,在自己身上就能找到。
fun.test2():test2是在Fun的原型对象上添加的,fun对象在自身寻找test2方法没找到,此时会通过fun.__proto__找到该对象的隐式原型对象,也就是Fun.prototype(构造函数Fun的原型空Object对象),最终在Fun.prototype身上找到了test2方法。
fun.toString():fun在自身寻找toString方法没找到,接着通过fun.__proto__向上找,在Fun.prototype身上也没找到,继续沿着__proto__上找,在Object.prototype身上找到了toString方法并调用。
fun.test3():fun在自身寻找test3方法没找到,接着通过fun.__proto__向上找,在Fun.prototype身上也没找到,继续沿着__proto__上找,在Object.prototype身上也没找到,打印undefined。
console.log(fun.test3); // undefined
fun.test3(); // fun.test3 is not a function
总结:方法一般会被定义在原型中,属性一般通过构造函数定义在对象身上,因为属性都带有个性特征,但方法可以普遍地供每个实例对象使用,每个对象用的时候只需要沿着原型链向上查找即可,就不需要额外占用内存。
instanceof经典问题辨析
instanceof用来判断一个对象是否是另一个对象的实例,例如可以使用A instanceof B来判断A是否为B的实例。即B的显式原型是否位于A的原型链上。
console.log(Fun.prototype instanceof Object) //true
举例:
console.log(Object instanceof Function)
console.log(Object instanceof Object)
console.log(Function instanceof Function)
console.log(Function instanceof Object)
(1)判断A是否为B的实例
(2)判断B.prototype是否位于A的原型链上。
结论:
- 所有函数都是由Function构造函数实例化而来
- Function也是由Function构造函数构造出来的实例
- 基本上所有的对象都是Object构造函数的实例(Object.prototype除外)
Function instanceof Object
- prototype:Object -> Object.prototype
- __proto__:Function -> Function.prototype -> Object.prototype
Object instance of Object
- prototype:Object -> Object.prototype
- __proto__:Object -> Function.prototype -> Object.prototype
Function instance of Function
- prototype:Function -> Function.prototype
- __proto__:Function -> Function.prototype
Object instanceof Function
- prototype:Function -> Function.prototype
- __proto__:Object -> Function.prototype
因此:
console.log(Object instanceof Function) //true
console.log(Object instanceof Object) //true
console.log(Function instanceof Function) //true
console.log(Function instanceof Object) //true
假如在这个例子上加一个函数对象Foo呢,Object instanceof Foo,如何判断?
Object instanceof Foo
- prototype:Foo -> Foo.prototype
- __proto__:Object -> Function.prototype -> Object.prototype
结果是:false,可以看到Foo并没有出现在__proto__原型链上。
总结:每个函数的原型又叫构造函数的原型对象。既然是一个对象,就是Object的实例。如果一个对象是Object的实例对象,则__proto__属性必须有值。但是Object原型对象Object.prototype并不是Object的实例对象,他是原型链的终点,所以__proto__属性值为null。因此Object.prototype instanceof Object 为false
console.log(Object.prototype instanceof Object) //false
2、案例分析
// 练习一:
function A() {};
A.prototype.n = 1;
var b = new A();
A.prototype = {n: 2,m: 3
}var c = new A();
console.log(b.n, b.m, c.n, c.m);
练习一:
b是A的实例对象,因此可以使用A原型定义的变量n=1,所以b.n输出为1。
注意在b实例化后,才在A的原型上新增了m和n属性,因此在b获取的时候并没有获取到m的值,所以为undefined。
c是A的实例化对象可以正常访问A中的属性,输出2,3
// 练习二:
function F() {};
Object.prototype.a = function(){console.log('a()');
}
Function.prototype.b = function(){console.log('b()');
}var f = new F();
f.a();
f.b();
F.a();
F.b();
练习二:
f是F的实例对象,调用a方法在自身找不到,则去__proto__上找到Object.prototype里面有a方法,因此正常打印。
f在自身找不到b方法,去Object.prototype上也找不到,因此报错,输出f.b is not a function
F是Function的实例对象,在自身找不到a方法,则去__proto__上找Function.prototype发现也没找到,继续向上找到Object.prototype,找到里面的a方法,正常输出a()
F在自身找不到b方法,去Function.prototype中找到了b方法,正常输出b()
原理
原型链本质就是一个链表,是js实现继承的一种机制。
任何对象(函数)内部都有一个原型对象(prototype),new 实例对象创建成功后,会加上一个__proto__属性,称为它的隐式原型,当我们访问对象上的属性或方法的时候,如果在当前对象自身找不到,js就会沿着__proto__一层层向上找,直到找到该属性或者方法,或者到达原型链的终点,即Object.prototype.__proto__为null,为止。这就是原型链。
好处优点
所有对象都可以共享原型链的方法,从而实现属性和方法的继承,达到节省内存的效果。
原型链应用场景
- jQuery,$ 就放在jQuery的原型链上,我们用 $ 拿属性
- Vue 的axios也是放在vue的原型链上,我们使用 $ axios在文件的任何位置都可以访问这个方法
- 数组方法Array.prototype
原型/原型链总结:
- 原型链是JavaScript实现继承的一种机制
- 任何函数都有一个prototype,称为这个函数的原型
- 这个函数也可以把它当成一个构造函数,通过new出一个实例
- 实例创建成功后自动加上一个__proto__,称为它的隐式原型
原型链是JavaScript中一个复杂但强大的特性,它允许对象之间共享属性和方法,并通过原型链实现类似传统面向对象编程语言的继承机制,掌握原型链的概念和用法对于深入理解JavaScript的面向对象编程至关重要。
相关文章:
原型与原型链
建议大家看的时候手动画图!!!这点很重要!!! 原型链在结构上很像链表,每个对象中都保存着一个地址,指向当前对象的原型,可以层层向上查找,起到继承的效果。 …...
TIM定时中断
TIM定时中断 文章目录 TIM定时中断1.TIM定时器1.1定时器的定义1.1.1基本定时器1.1.2通用定时器1.1.3高级定时器 2.计数器有预装时序3.定时器结构及涉及的函数解析3.1定时中断基本结构3.2实现步骤3.3TIM本小节的库函数解释说明3.4计数器计数频率和计数器溢出频率 4.定时器定时中…...
Windows 上的 MySQL 8.4.3 和 WSL(Ubuntu)的 MySQL 8.0.40 之间配置 主从同步
在 Windows 上的 MySQL 8.4.3 和 WSL(Ubuntu)的 MySQL 8.0.40 之间配置 主从同步(Master-Slave Replication) 的过程略有不同,因为两者的 MySQL 版本和环境存在差异。以下是详细步骤,帮助你完成跨平台的主从…...
中职网络建设与运维ansible服务
ansible服务 填写hosts指定主机范围和控制节点后创建一个脚本,可以利用简化脚本 1. 在linux1上安装系统自带的ansible-core,作为ansible控制节点,linux2-linux7作为ansible的受控节点 Linux1 Linux1-7 Yum install ansible-core -y Vi /etc/ansible/hosts 添加…...
jmeter事务控制器-勾选Generate Parent Sample
1、打开jmeter工具,添加线程组,添加逻辑控制器-事务控制器 2、在事务控制器,勾选Generate parent sample:生成父样本;说明勾选后,事务控制器会作为父节点,其下面的请求作为子节点 3、执行&#…...
win32汇编环境,窗口程序中对多行编辑框的操作
;运行效果 ;win32汇编环境,窗口程序中对多行编辑框的操作 ;比如生成多行编辑框,显示文本、获取文本、设置滚动条、捕获超出文本长度消息等。 ;直接抄进RadAsm可编译运行。重点部分加备注。 ;下面为asm文件 ;>>>>>>>>>>>>>&g…...
Java反射、静态代理、动态代理
往期推荐 Java io模型-CSDN博客 如何设计一个能根据任务优先级来执行的线程池-CSDN博客 Web实时消息推送的几种方案_setmessageinnerhtml is not defined-CSDN博客 yum、dnf、apt包管理工具-CSDN博客 概述 反射机制是在运行状态中,对于任意一个类,都能够…...
在Android 15的设备上关闭edge-to-edge功能
Android 15在开发上有很多更新,当APP的targetSdk设置为35,且设备系统为Android 15时,APP会自动启动edge-to-edge功能。虽然可视面积变大了,但界面布局也会受影响。 如果要强制关闭edge-to-edge功能。可以在style.xml中将windowOp…...
GIS大模型:交通领域方面的应用
文章目录 1. 实时交通流量预测:2. 动态信号灯控制:3. 交通流模式识别:4. 交通事故预警:5. 路径推荐与导航优化:6. 长期交通规划:7. 事件影响分析:8. 智能停车管理: 大模型在交通流量…...
Vi 和 Vim 文本编辑器使用指南
目录 基本模式 查找与替换 Vi(Visual)和 Vim(Vi Improved)是两款在 Unix/Linux 系统中广泛使用的文本编辑器。Vim 是 Vi 的改进版本,继承了 Vi 的核心功能,并增加了许多新特性,如语法高亮、多…...
redis acl
redis acl redis 安全访问控制 官网 本文基于redis 6.2.17 版本进行测试验证 使用方式 redis 使用 acl 的配置有2种方式:使用 redis.conf 文件配置,和在 redis.conf 文件中配置 aclfile path 指定外部 aclfile 文件路径 使用 redis.conf 文件配置 …...
Linux Centos 安装Jenkins到服务
一、前言 假设你已经下载了jenkins.war 安装了对应的jdk,下面我们来安装jenkins,以服务的形式安装。 二、安装 1)将jenkins.war拷贝到合适的位置,我的位置 /u01/jenkins/ ,位置你自己选。 2)创建系统用户…...
WINFORM - DevExpress -> gridcontrol ---->控件(ColumnEdit控件)
ImageComboBoxEdit--带图片的下拉菜单 DevExpress:带图片的下拉菜单ImageComboBoxEdit_weixin_34313182的博客-CSDN博客 ImageEdit--图片按钮 DevExpress控件中的gridcontrol表格控件,如何在属性中设置某一列显示为图片(图片按钮ÿ…...
工作中redis常用的5种场景
在日常开发工作中,Redis作为一款高性能的内存数据库,凭借其强大的功能特性和卓越的性能表现,已经成为了许多项目中不可或缺的组件。本文将详细介绍Redis在实际工作中最常见的5种应用场景,并附上具体的代码实现。 1. 缓存热点数据…...
得物App利用技术赋能,打造潮流消费“新玩法”
如今,技术的力量正在以前所未有的方式重塑着我们的消费体验。从线上购物到虚拟现实,技术的角色越来越重要,它不仅是推动商业发展的引擎,更是满足年轻消费者多元化、个性化需求的关键。得物App作为一个年轻人喜爱的潮流消费平台&am…...
tomcat状态一直是Exited (1)
docker run -di -p 80:8080 --nametomcat001 你的仓库地址/tomcat:9执行此命令后tomcat一直是Exited(1)状态 解决办法: 用以下命令创建运行 docker run -it --name tomcat001 -p 80:8080 -d 你的仓库地址/tomcat:9 /bin/bash最终结果 tomcat成功启动...
015: 深度学习之正向传播和反向传播
本文为合集收录,欢迎查看合集/专栏链接进行全部合集的系统学习。 合集完整版请参考这里。 上一节介绍了训练和推理的概念,这一节接着训练和推理的概念讲一下,神经网络的正向传播和反向传播。 正反向传播 其实单看正向传播和反向传播这两个…...
ubuntu下安装编译cmake,grpc与protobuf
文章目录 install cmakeinstall grpcinstall protobuf注 install cmake sudo apt-get install -y g make libssl-devcd third_party/cmake-3.17.2./configuresudo make && make installcmake --version install grpc $ sudo apt-get install -y build-essential auto…...
如何在Mac上使用Brew更新Cursor应用程序
在这篇博文中,我们将介绍如何在Mac上更新Cursor应用程序,以及一些相关的使用技巧和功能。 什么是Cursor? Cursor是一款强大的工具,旨在帮助用户更好地编写、编辑和讨论代码。它结合了AI技术,使得编程过程更加高效和便…...
玩转大语言模型——使用graphRAG+Ollama构建知识图谱
系列文章目录 玩转大语言模型——ollama导入huggingface下载的模型 玩转大语言模型——langchain调用ollama视觉多模态语言模型 文章目录 系列文章目录前言下载和安装用下载项目的方式下载并安装用pip方式下载并安装 生成知识图谱初始化文件夹修改模型配置修改知识库生成配置创…...
LevelDB 源码阅读:如何优雅地合并写入和删除操作
LevelDB 支持写入单个键值对和批量写入多个键值对,这两种操作的处理流程本质上是相同的,都会被封装进一个 WriteBatch 对象中,这样就可以提高写操作的效率。 在 LevelDB 中,WriteBatch 是通过一个简单的数据结构实现的࿰…...
Vue.js 组件的生命周期钩子
Vue.js 组件的生命周期钩子 在 Vue.js 中,组件的生命周期是指组件从创建到销毁的整个过程。在这个过程中,Vue 提供了多个 生命周期钩子,让我们可以在不同的阶段执行特定的逻辑。掌握这些钩子非常重要,它们能帮助我们灵活控制组件…...
VD:生成a2l文件
目录 前言Simulink合并地址 ASAP2 editor 前言 我之前的方法都是通过Simulink模型生成代码的过程中顺便就把a2l文件生成出来了,这时的a2l文件还没有地址,所以紧接着会去通过elf文件更新地址,一直以为这是固定的流程和方法,今天无…...
【C++ 类和对象 进阶篇】—— 逻辑森林的灵动精灵,舞动类与对象的奇幻圆舞曲
欢迎来到ZyyOvO的博客✨,一个关于探索技术的角落,记录学习的点滴📖,分享实用的技巧🛠️,偶尔还有一些奇思妙想💡 本文由ZyyOvO原创✍️,感谢支持❤️!请尊重原创…...
【Hive】海量数据存储利器之Hive库原理初探
文章目录 一、背景二、数据仓库2.1 数据仓库概念2.2 数据仓库分层架构2.2.1 数仓分层思想和标准2.2.2 阿里巴巴数仓3层架构2.2.3 ETL和ELT2.2.4 为什么要分层 2.3 数据仓库特征2.3.1 面向主题性2.3.2 集成性2.3.3 非易失性2.3.4 时变性 三、hive库3.1 hive概述3.2 hive架构3.2.…...
前端web
学习笔记: 基本属性 color: 设置文本的颜色。代码:color: red;background-color: 设置元素的背景颜色。background-color: blue;font-size: 设置文本的大小font-size: 16px;font-family: 设置文本的字体font-family: Arial, sans-serif;text-align: 设…...
如何通过 Nginx 实现 CouchDB 集群的负载均衡并监控请求分发
在现代分布式系统中,负载均衡是确保高可用性和性能的关键组件。CouchDB 是一个强大的分布式数据库,而 Nginx 是一个高性能的反向代理和负载均衡器。本文将详细介绍如何通过 Nginx 实现 CouchDB 集群的负载均衡,并监控请求被分发到哪一台 Couc…...
基于代理的RAG实现-Agentic RAG
基于代理的RAG实现-Agentic RAG Agentic RAG 体系结构中,不再被动地响应查询请求,而是主动地分析初步检索到的信息,并基于对任务复杂性的评估,战略性地选择最为合适的工具和方法进行进一步的数据检索和处理。这种多步骤推理和决策…...
ZIP怎么加密?
想要禁止他人随意解压zip压缩包,我们可以加密zip文件,那么zip设置密码的方法有哪些?今天分享三个加密方法 工具:WinRAR,这里需要注意,WinRAR默认压缩格式是.rar,所以我们想要加密zip文件&#…...
森林网络部署,工业4G路由器实现林区组网远程监控
在广袤无垠的林区,每一片树叶的摇曳、每一丝空气的流动,都关乎着生态的平衡与安宁。林区监控正以强大的力量,为这片绿色家园筑起一道坚固的防线。 工业 4G 路由器作为林区监控组网的守护者,凭借着卓越的通讯性能,突破…...
汽车网络信息安全-ISO/SAE 21434解析(上)
目录 概述 第四章-概述 1. 研究对象和范围 2. 风险管理 第五章-组织级网络安全管理 1. 网络安全治理(cybersecurity governance) 2. 网络安全文化(cybersecurity culture) 3. 信息共享(Information Sharing) 4. 管理体系…...
一个方法被多个线程同时调用,确保同样参数的调用只能有一个线程执行,不同参数的调用则可以多个线程同时执行
我们知道通过lock一个固定静态object给代码段加同步锁,可以让多个线程的同时调用以同步执行,因此可以利用字典来给不同参数分配不同的静态对象,方法中不同的参数调用锁住各自不同的静态对象即可实现不同参数不加锁,相同参数才加锁…...
军用通信设备通用规范GJB367A-2001试验
军用通信设备通用规范GJB367A-2001通常适用于地面、舰载和机载设备的型式试验验收标准,地面设备分为便携式设备、固定式设备和车载式设备。 GJB367A-2001军用通信设备通用规范规定了军用通信设备或系统的通用要求和检验验收规则以及试验方法。 GJB367A-2001军用通…...
AWS云计算概览(自用留存)
目录 一、云概念概览 (1)云服务模型 (2)云计算6大优势 (3)web服务 (4)AWS云采用框架(AWS CAF) 二、云经济学 & 账单 (1)定…...
AWS云平台上生成式AI通过项目文档内容分析获知项目风险
要在AWS云平台上设计和实施高性能系统,同时使用生成式人工智能识别项目风险来分析项目文档内容。 利用生成式AI分析项目文档并协助风险管理可以显著提高识别和解决AWS上托管的复杂项目中的风险的速度、准确性和效率。通过将AI的功能与传统的项目管理最佳实践相结合&…...
搜广推日常实习面经一
写在前面:除了校招的面经,实习的面经我也会更新,毕竟俺后续可能还要找一段实习。从八股来看,实习的八股更加的八股一点。和校招的面经有点不一样,所以还是可以学习了解一下。总之一句话:面向工作学习&#…...
分布式CAP理论介绍
分布式CAP理论是分布式系统设计中的一个核心概念,由加州大学伯克利分校的Eric Brewer教授在2000年的ACM研讨会上首次提出,随后在2002年由Seth Gilbert和Nancy Lynch从理论上证明。以下是对分布式CAP理论的详细剖析: 文章目录 一、CAP理论的基本概念二、CAP理论的取舍策略三、…...
网格参数化,Mesh parameterization processing
目录 前言1.Barycentric mappingMapping 步骤实例 2.Laplace mapping3.Laplace improvement4.Coding 前言 多边形网格的类型多种多样。本文所实现的网格多边形参数化是指三角多边形。 不同的表示被用来编码三维物体的几何形状。选择一种表示方式取决于在上游的获取过程和下游的…...
路由环路的产生原因与解决方法(1)
路由环路 路由环路就是数据包不断在这个网络传输,始终到达不了目的地,导致掉线或者网络瘫痪。 TTL (生存时间):数据包每经过一个路由器的转发,其数值减1,当一个数据包的TTL值为0是,路…...
编程工具箱(免费,离线可用)
https://www.yuque.com/huanmin-4bkaa/ii1hx1?# 《工具箱》 常用的大部分工具都有, 比如mysql可视化 redis可视化, json编辑器, 加解密等(免费,离线可用) 后续也会慢慢的集成...
从Arrays源码学习定义工具类
背景 在日常编码中,一个比较好的实践是:我们把一些业务无关的、可复用的一些通用逻辑,封装成工具类、甚至jar包。这样一方面方便通用代码抽取、代码复用,同时也隔离经常变动的业务代码和不变的通用代码。那如何定义好一个工具类呢…...
Unity中实现倒计时结束后干一些事情
问题描述:如果我们想实现在一个倒计时结束后可以执行某个方法,比如挑战成功或者挑战失败,或者其他什么的比如生成boss之类的功能,而且你又不想每次都把代码复制一遍,那么就可以用下面这种方法。 结构 实现步骤 创建一…...
FPGA随记——时钟时序一些基本知识
原文链接:跨时钟域设计-CSDN博客 前言 CDC(clock domain crossing)检查(跨时钟域的检查)是对电路设计中同步电路设计的检查。非同步时钟没有固定的相位关系,这样Setup/Hold不满足而产生了亚稳态是无法避免…...
【微服务】SpringBoot 通用异常处理方案使用详解
目录 一、前言 二、SpringBoot 异常介绍 2.1 SpringBoot 中异常定义 2.1.1 SpringBoot 异常处理机制的重要性 2.2 常用的异常分类 2.3 常用的异常处理解决方案 三、springboot 异常处理操作实践 3.1 springboot自适应错误处理机制 3.1.1 使用默认错误页面 3.1.2 自定义…...
初识MyBatis(详细)
目录 回顾 前提回忆下web应用程序的三层架构: 编辑 一.什么是MyBatis? 二.Mybatis操作数据库的步骤: 2.1准备工作 2.2配置Mybatis(数据库连接信息) 2.3写持久层代码 2.4测试 三.Mybatis配置文件 3.1打印日志 3.2参数传递…...
elementui表单验证,数据层级过深验证失效
先看示例代码,代码为模拟动态获取表单数据,然后动态添加rules验证规则,示例表单内输入框绑定form内第四层: <template><el-form :model"form" :rules"rules" ref"ruleForm" label-width&…...
HTTPS与HTTP:区别及安全性对比
目录 一、基础概念 二、安全性对比 1. 加密传输 2. 身份验证 3. 数据完整性 4. 端口 5. 浏览器展示方式 三、使用场景与性能 1. 使用场景 2. 性能开销 四、成本与维护 五、搜索引擎优化(SEO) 六、案例分析 七、隐私保护与中间人攻击 八、…...
中国石油大学(华东)自动评教工具(涵盖爬虫的基础知识,适合练手)
我开发了一个用于自动评教的工具,大家可以试着用用,下面是链接。 https://github.com/restrain11/auto_teachingEvaluate 可以点个星吗,感谢!🫡 以下是我在开发过程中学到的知识 以及 碰到的部分问题 目录 动态爬虫和静…...
蓝桥杯备考:二叉树详解
二叉树的概念和相关术语 二叉树的定义:每个结点度至多为2的树,叫二叉树 二叉树的子树有左右之分不可以随意颠倒顺序,也就是说二叉树是有序树 二叉树根结点左子树右子树 满二叉树:就是把每一层的结点都铺满 满二叉树的性质…...
大模型微调介绍-Prompt-Tuning
提示微调入门 NLP四范式 第一范式 基于「传统机器学习模型」的范式,如TF-IDF特征朴素贝叶斯等机器算法. 第二范式 基于「深度学习模型」的范式,如word2vec特征LSTM等深度学习算法,相比于第一范式,模型准确有所提高,…...