JavaScript 语言精粹读书笔记(第五章)

本文详细解释了JavaScript中伪类继承和原型继承的实现方式,通过实例展示了如何使用这两种方法来实现类的继承,并讨论了它们各自的优缺点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

伪类

当一个函数对象被创建的时候,Function构造器产生的函数对象会运行类型这样一些代码:

this.prototype={constructor:this};

新函数对象被赋予一个prototype属性,并且其值包含一个constructor属性且属性值为该新函数对象。 当使用new关键字去调用一个函数时,将修改函数的执行方式。 大致会执行以下几个过程:

  1. 创建一个新对象,继承自函数对象的原型(重点,继承非函数对象本身而是它的原型)
  2. 调用函数,绑定this到新对象上。(apply方法)
  3. 返回新对象

伪类方式的继承是通过定义一个构造函数以及替换prototype来实现的。
以下代码实现伪类继承 定义Person类构造函数以及定义getName方法

var Person= function (name) {
    this.name=name;
}

Person.prototype.getName=function(){
    return this.name;
}

定义学生类构造函数并继承Person获得getName方法

var Student=function(name,num){
    this.name=name;
    this.num=num;
}

Student.prototype=new Person();
Student.prototype.getNum= function () {
    return this.num;
}

这种继承方式,所有属性可以被随意修改,并且无法访问父类的方法。

原型

基于原型的继承更为简单。使用对象字面量创建一个对象,其他对象可以直接通过prototype即可完成继承。

函数化

前两种继承方式都存在属性对外可见的问题,而利用模块模式可以避免这种缺陷。通常需要以下几个步骤:

  1. 创建一个对象可以(可以使用包括new、对象字面量等任何方式)。
  2. 选择性的定义私有变量和方法(通过var)。
  3. 给新对象扩充方法,这些方法拥有特权访问参数以及第二步定义的私有变量。
  4. 返回新对象。

下面代码使用这种方式实现继承
var person= function (pro) {
    var that={};
    that.getName=function(){
        return pro.name;
    }
    return that;
}

var student=function(pro){
    var that=person(pro);
    that.getNum= function () {
        return pro.num;
    }
    return that;
}

这种方式还避免原型方式需要重写构造函数的麻烦,我们只需要调用父类构造函数,然后专注差异部分的创建。

这种继承方式还可以调用父类的方法。
内容概要:该论文聚焦于T2WI核磁共振图像超分辨率问题,提出了一种利用T1WI模态作为辅助信息的跨模态解决方案。其主要贡献包括:提出基于高频信息约束的网络框架,通过主干特征提取分支和高频结构先验建模分支结合Transformer模块和注意力机制有效重建高频细节;设计渐进式特征匹配融合框架,采用多阶段相似特征匹配算法提高匹配鲁棒性;引入模型量化技术降低推理资源需求。实验结果表明,该方法不仅提高了超分辨率性能,还保持了图像质量。 适合人群:从事医学图像处理、计算机视觉领域的研究人员和工程师,尤其是对核磁共振图像超分辨率感兴趣的学者和技术开发者。 使用场景及目标:①适用于需要提升T2WI核磁共振图像分辨率的应用场景;②目标是通过跨模态信息融合提高图像质量,解决传统单模态方法难以克服的高频细节丢失问题;③为临床诊断提供更高质量的影像资料,帮助医生更准确地识别病灶。 其他说明:论文不仅提供了详细的网络架构设计与实现代码,还深入探讨了跨模态噪声的本质、高频信息约束的实现方式以及渐进式特征匹配的具体过程。此外,作者还对模型进行了量化处理,使得该方法可以在资源受限环境下高效运行。阅读时应重点关注论文中提到的技术创新点及其背后的原理,理解如何通过跨模态信息融合提升图像重建效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值