1.prototype(原型)

本文深入探讨JavaScript中原型的概念及其在对象创建和继承过程中的应用。通过具体代码示例,展示如何通过原型对象实现属性和方法的共享,并阐述原型链的原理与作用。文章进一步解释了原型、构造函数与实例之间的关系,以及如何利用原型链实现子类继承父类的特性。
2.    //定义Person方法并创建两个Person实例  
3.    function Person(){}  
4.    var person1 = new Person();  
5.    var person2 = new Person();  
6. 
7.    //为Person的原型增加name属性和sayName方法 
  8.    //即使在实例的创建之后定义,但对实例也是立即可见的  
9.    Person.prototype.name = "Peter";  
10.    Person.prototype.sayName = function(){return this.name;};  
11.      
12.    //所有实例共享原型上的属性或者方法  
13.    alert(person1.name);        //Peter  
14.    alert(person2.name);        //Peter  
15.    alert(person1.sayName());   //Peter  
16.    alert(person2.sayName());   //Peter  
17.      
18.    //当实例中有同名的变量或者方法时,prototype的属性或者方法则被隐藏了(并非覆盖)  
19.    person1.name="Billy";  
20.    alert(person1.name);        //Billy  
21.    delete person1.name;  
22.    alert(person1.name);        //Perter  
23.      
24.    //使用hasOwnProperty()可以判断某个属性是否为自有属性  
25.    alert(person1.hasOwnProperty("name"));//false  
26.    person1.name="Jack";  
27.    alert(person1.hasOwnProperty("name"));//false  
28.</script> 
2.原型、构造函数和实例之间的关系
当我们定义一个函数的时候,它的默认的prototype对象便随之产生,这个prototype对象有一个construtor属性指向该函数,而使用该函数创建的所有实例内部都含有一个指针__proto__指向prototype对象(IE8中不能访问该指针):
1.<script type="text/javascript">  
2.    function Person(){}  
3.    alert(Person.prototype);                    //[object Object]  
4.      
5.    //prototype的constructor属性指向Person  
6.    alert(Person.prototype.constructor);        //function Person(){}  
7.    alert(Person.prototype.constructor == Person);//true  
8.      
9.    //每个实例存在一个__proto__指针指向Person.prototype  
10.    //IE中不能访问  
11.    var person = new Person();  
12.    alert(person.__proto__);                    //[object Object]  
13.    alert(person.__proto__==Person.prototype);  //true(IE为false)  
14.</script> 3.原型链与继承
一个prototype是一个对象,因此,它必然有一个__proto__指针指向构造函数的prototype对象,同样道理,这个prototype对象又有一个__proto__指针指向构造函数的prototype对象,这样一环接一环直到Object.prototype,这就组成了一条原型链。当我们调用某个实例的属性或者方法的时候,首先从该实例寻找该变量或者方法,若找到则返回;否则寻找__proto__所指向的prototype对象,若还是没找到则继续寻找其__proto__指向的对象,直到找到或者到达原型链的末尾为止。我们可以通过这种查找方式实现继承。
1.function SuperType(name)  
2.{  
3.        this.name = name;  
4.}  
5.                   
6.SuperType.prototype.sayName = function(){ 
  7.        alert(this.name);  
8.};  
9.                   
10.function SubType(name, age)  
11.{    
12.        SuperType.call(this, name);  
13.        this.age = age;  
14.}  
15. 
16.    SubType.prototype = new SuperType();  
17.                   
18.SubType.prototype.sayAge = function()  
19.{  
20.        alert(this.age);  
21.};  

转载于:https://www.cnblogs.com/qiuwenjuan/p/3308098.html

内容概要:本文系统介绍了算术优化算法(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、付费专栏及课程。

余额充值