既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
JavaScript
同样存在由原型指向构造函数的属性:constructor
,即Func.prototype.constructor --> Func
5. __proto__
JavaScript
中所有对象(除了null
)都具有一个__proto__
属性,该属性指向该对象的原型。
function User() {}
var u1 = new User();
// u1.\_\_proto\_\_ -> User.prototype
console.log(u1.__proto__ === User.prototype) // true
显而易见,实例的__proto__
属性指向了构造函数的原型,那么多个实例的__proto__
会指向同一个原型吗?
var u2 = new User();
console.log(u1.__proto__ === u2.__proto__) // true
其实学到这里就可以产生一些骚想法了,多个实例的__proto__
都指向构造函数的原型,那么实例如果能通过一种方式,访问原型上的方法,属性等,就可以实现继承的效果。
我们继续更新一下原型与原型链的关系图:
6. 原型链
实例对象在查找属性时,如果查找不到,就会沿着__proto__
去与对象关联的原型上查找,如果还查找不到,就去找原型的原型,直至查到最顶层,这也就是原型链的概念。
就借助面试题,举几个原型链的例子:
6.1举例
u1.sayHello()
:
u1
上是没有sayHello
方法的,因此访问u1.__proto__(User.prototype)
,成功访问到sayHello
方法u2.toString()
u2,User.prototype
都没有toString
方法,User.prototype
也是一个普通对象,因此继续寻找User.prototype.__proto__(Object.prototype)
,成功调用到toString
方法
7. 提高升华
学完上面那些,大多数面试题都可以做出来了,例如下面这种
function A() {}
function B(a) {
this.a = a;
}
function C(a) {
if (a) {
this.a = a;
}
}
A.prototype.a = 1;
B.prototype.a = 1;
C.prototype.a = 1;
console.log(new A().a); //1
console.log(new B().a); //undefined
console.log(new C(2).a); //2
但距离解决文章的最初的面试题还欠缺些什么,比如Function.__proto__ === Object.__proto__、Function.prototype.__proto__ === Object.prototype.__proto__
等,接着我们来一一攻克它。
7.1 Objcet.__proto__
、 Object.prototype
、Object.prototype.__proto__
Object
是构造函数,在第二部分我们讲过所有的函数都是通过new Function
创建了,因此Object
相当于Function
的实例,即Object.__proto__ --> Function.prototype
。Object.prototype
是Object
构造函数的原型,处于原型链的顶端,Object.prototype.__proto__
已经没有可以指向的上层原型,因此其值为null
// 总结:
Object.__proto__ --> Function.prototype
Object.prototype.__proto__ --> null
7.2 Function.__proto__
、Function.prototype
、Function.prototype.__proto__
-
Function.prototype
是Function
的原型,是所有函数实例的原型,例如上面讲的Object.__proto__
-
Function.prototype
是一个普通对象,因此Function.prototype.__proto__ --> Object.prototype
-
Function.__proto__
:__proto__
指向创造它的构造函数的原型,那谁创造了Function
那?-
猜想:函数也是对象,那
Function.__proto__
会指向Object.prototype
吗?但上文提到,Object
是new Function
生成,Object.__proto__ --> Function.prototype
。如果真的如此指向,未免有些混乱,因此我去做了一下测试:
实践证明只存在Object.__proto__ --> Function.prototype
-
苦思冥想没得出结果,难道
Function
函数是猴子不成,从石头缝里面蹦出来的?于是我进行了一同乱七八糟的测试,没想到找出了端倪。
-
Function
函数不通过任何东西创建,JS
引擎启动时,添加到内存中
7.3 升华
最后将原型与原型链方面的知识凝结成一张图:
- 所有函数(包括
Function
)的__proto__
指向Function.prototype
- 自定义对象实例的
__proto__
指向构造函数的原型 - 函数的
prototype
的__proto__
指向Object.prototype
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
里获取](https://bbs.csdn.net/topics/618668825)**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!