准备之JavaScript实现继承的常用方法

本文深入探讨JavaScript中实现继承的三种常见方法:原型链、借用构造函数及组合继承,对比各自的优缺点,帮助开发者理解并选择合适的继承策略。
/**
 * JavaScript实现继承的常用方法有哪些?你推荐的是哪一种?
 * 1.原型链
 *   基本思想:利用原型让一个引用类型继承另一个引用类型的属性和方法
 * 
 *   JS中构造函数、实例对象和原型对象三者之间的关系:
 *       构造函数.prototype-->原型对象
 *       原型对象.constructor--> 构造函数
 *       实例对象 = new 构造函数() 
 *       实例对象.__proto__ --> 原型对象
 *   存在问题:   
 *       1.包含引用类型值的原型属性被所有实例共享,这会导致对一个实例修改会影响另一个实例
 *       2.在创建子类实例时,不能向父类的构造函数传递参数
 * 2.借用构造函数
 *    基本思想:在子类的构造函数中,通过 apply () 或 call ()的形式,调用父类构造函数,以实现继承。
 *    弊端:无法实现函数复用  因为它只是改变了this指向,原型对象还是自己的原型对象,并不是所继承的对象的原型对象,
 *         所以被继承原型对象的原型对象上的方法与属性,访问不到
 * 3.组合继承 √
 *    基本思想:使用原型链实现对原型方法的继承,而通过借用构造函数来实现对实例属性的继承
 *    有点:既通过在原型上定义方法实现了函数的复用,又能够保证每个实例都有它自己的属性
 * */


//1.原型链继承
// function SupperType(name) {
//     this.name = name;
//     this.property = 'SupperType->property';
//     this.colors = ['red', 'green'];
// }
// SupperType.prototype.getSupperTypeValue = function() {
//     return this.property;
// }

// function SubType() {
//     this.subProperty = 'SubProperty->property';
// }
// SubType.prototype = new SupperType('测试');
// SubType.prototype.getSubPropertyValue = function() {
//     return this.SubProperty;
// };
// var value = new SubType();
// console.log(SubType.prototype.constructor === SubType);
// console.log(value.__proto__ === SubType.prototype); //true  
// console.log(value.getSupperTypeValue()); //SupperType->property
// // 问题1演示
// var a = new SubType();
// a.colors.push('black');
// console.log(a)
// var b = new SubType();
// console.log(b)
// console.log(b.colors) //[ 'red', 'green', 'black' ]
// console.log(a.name) //测试


// 借用构造函数  
// function SupperType(name) {
//     this.name = name;
//     this.property = 'SupperType->property';
//     this.colors = ['red', 'green'];
// }
// SupperType.prototype.getSupperTypeValue = function() {
//     return this.property;
// }
// SupperType.prototype.age = '18';

// function SubType(name) {
//     this.subProperty = 'SubProperty->property';
//     SupperType.call(this, name);
//     this.property = '11'; //
// }
// var s = new SubType('zs');
// var s2 = new SubType('zs2');
// console.log(s);
// console.log(s.name); //zs
// console.log(s2.name); //zs2
// console.log(s.property); //SupperType->property
// console.log(s.subProperty); //SubProperty->property
// // console.log(s.getSupperTypeValue()); // s.getSupperTypeValue is not a function
// console.log(s.age); //undefined
// console.log(SubType.prototype); // SubType
// console.log(SubType.prototype.constructor); // SubType



// 组合继承
// function SupperType(name) {
//     this.name = name;
//     this.colors = ['red', 'green'];
// }
// SupperType.prototype.sayName = function() {
//     return this.name;
// }

// function SubType(name, age) {
//     SupperType.call(this, name);
//     this.age = age;
// }
// SubType.prototype = new SupperType();
// var sub1 = new SubType('name->sub1');
// sub1.colors.push('yellow');
// console.log(sub1);
// console.log(sub1.colors); //['red', 'green','yellow']
// console.log(sub1.sayName()); //name->sub1
// var sub2 = new SubType('name->sub2');
// console.log(sub2.colors); //['red', 'green']
// console.log(sub2.sayName()); //name->sub2

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值