[基础]JavaScript中的面向对象(个人学习笔记) 一

最近总是遇见JavaScript中对象和类的问题,于是重新学习JavaScript,也把它当作自己的第一篇学习笔记,如果有理解错误的地方,请大家指出,谢谢。
首先说明一下ECMAScript,它是在一个叫做ECMA-262的标准中定义的,ECMAScript
一个重要的标准,它可以为不同的宿主环境提供核心的脚本编程能力,是一个JavaScript的核心。通常一个完整的JavaScript实现是由以下三个不同部分组成:
 核心(ECMAScript)
 文档对象模型(DOM)
 浏览器对象模型(BOM)
*以下内容正式开始,一切还是从对象入手

1、面向对象术语
[b]对象(Object)[/b]
ECMA-262把‘对象’定义为“属性的无序组合,每个属性存放一个原始值、对象或函数”。‘对象’由特性(attribute)构成,特性可以使原始值,也可以是引用值。如果特性存放的是函数,它被看作对象的方法(method),否则该特性被看作属性(property)。

[b]类(Class)[/b]
ECMAScript并没有正式的类。其实对象的定义就是类的定义。类定义了一个对象的属性和方法,还有一些相关业务的代码。对象的定义放在类的构造函数中。

2、对象的声明和实例化
对象是用关键字new后跟要实例化的类名创建:

var oObject = new Object();
var sString = new String();

上面的代码就分别创建了一个Object对象和一个String对象。如果类的构造函数没有参数,括号是不必需的。所以上面的代码可以改写成:

var oObject = new Object;
var sString = new String;

3、对象的废除
先说概念,当再没有对对象的引用时,就称该对象被废除(dereference)了。说到对象的废除,就不得不说[color=red]无用储存单元收集程序[/color],每当程序执行完它的代码,无用储存单元收集程序都会运行,释放所有局部变量,还有一些不可知的情况它也会运行。
把对象的所有引用都设置成null,可以强制性的废除对象。比如:

var oObject = new Objcet;
//do something here
oObject = null;


当变量oObject设置成null后,就没有任何对对象的引用了。这意味着下次运行无用储存单元收集程序时,该对象将被销毁。
[b]*每用完一个对象后,就将其废除,来释放内存,这是一个好习惯。
*废除对象的引用时要当心。如果一个对象有两个或多个引用,要废除该对象,则需要将对象的所有引用都设置成null![/b]
最后还要补充一个问题,说一下为什么javascript中没有重载。在ECMAScript中函数实际上是功能完整的对象,实际上是创建了一个Function类的实例对象。用Function类直接创建函数的语法如下:

var function_name = new Function(argument1,argument2, …,argument,function_body);

先来看一段简单的代码:

function sayHello(name,msg){
alert("Hello" + name + "you are very " + msg);
}

通过Function类可以将原代码改写成:

var sayHello = new Function("name","msg","alert(\"Hello \" + name + \", you are very\" + msg );");
sayHello("yzl","handsome");

以上的两段代码都实现的相同的功能,实际上更应该说成是第一段代码最后都会被计算机理解为第二段,个人感觉跟高级语言被转换为机器语言一样,所以很容易可以看出在定义函数时无法实现重载,因为在第二次定义函数的时候已经把函数的引用指向了新的引用,就好像你对同一个变量new了两次一个道理,第一个函数已经“不在”了。
[b]*Function中有个很重要的东西arguments放到了类的初始化那里说明[/b]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像的目标属于哪个类别。 定位问题:确定目标在图像的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值