- 浏览: 185176 次
- 性别:
- 来自: 杭州
-
文章分类
最新评论
-
abc20899:
对啊!报错!楼主你测试了吗?
Java7 - 新特性之对集合类的语言支持 -
zskangs1126:
Facebook 的系统架构 -
ccxiajie:
List list={"hello"}; ...
Java7 - 新特性之对集合类的语言支持 -
luoyahu:
请不要把你的兴趣变成工作,因为那样会毁了你的兴趣。
一些对程序员的建议(不要轻易的让人帮你决定,那怕是你的家人) -
coral0212:
我也尝试创过业,但我觉得我这种人是“谋士”,不是能攻城拔寨的“ ...
一些对程序员的建议(不要轻易的让人帮你决定,那怕是你的家人)
尽管 JavaScript 支持一对花括号创建的代码段,但是并不支持块级作用域; 注意: 如果不是在赋值语句中,而是在 return 表达式或者函数参数中, 译者注:如果 JavaScript 中没有显式的命名空间定义,这就意味着所有对象都定义在一个全局共享的命名空间下面。 每次引用一个变量,JavaScript 会向上遍历整个作用域直到找到这个变量为止。 上面两段脚本效果不同。脚本 A 在全局作用域内定义了变量 再次强调,上面的效果完全不同,不使用 在函数 外部循环在第一次调用 JavaScript 中局部变量只可能通过两种方式声明,一个是作为函数参数,另一个是通过 JavaScript 会提升变量声明。这意味着 上面代码在运行之前将会被转化。JavaScript 将会把 没有块级作用域不仅导致 在原来代码中, 如果没有提升规则(hoisting)的知识,下面的代码看起来会抛出异常 实际上,上面的代码正常运行,因为 译者注:在 Nettuts+ 网站有一篇介绍 hoisting 的文章,其中的代码很有启发性。 JavaScript 中的所有作用域,包括全局作用域,都有一个特别的名称 函数作用域内也有默认的变量 比如,当访问函数内的 注意: 自定义 只有一个全局作用域导致的常见错误是命名冲突。在 JavaScript中,这可以通过 匿名包装器 轻松解决。 匿名函数被认为是 表达式;因此为了可调用性,它们首先会被执行。 有一些其他的调用函数表达式的方法,比如下面的两种方式语法不同,但是效果一模一样。 推荐使用匿名包装器(译者注:也就是自执行的匿名函数)来创建命名空间。这样不仅可以防止命名冲突, 另外,使用全局变量被认为是不好的习惯。这样的代码倾向于产生错误和带来高的维护成本。作用域与命名空间
而仅仅支持 函数作用域。function test() { // 一个作用域
for(var i = 0; i < 10; i++) { // 不是一个作用域
// count
}
console.log(i); // 10
}
{...}
将会作为代码段解析,
而不是作为对象的字面语法解析。如果考虑到 自动分号插入,这可能会导致一些不易察觉的错误。return
对象的左括号和 return
不在一行上就会出错。// 译者注:下面输出 undefined
function add(a, b) {
return
a + b;
}
console.log(add(1, 2));
如果到达全局作用域但是这个变量仍未找到,则会抛出 ReferenceError
异常。隐式的全局变量
// 脚本 A
foo = '42';
// 脚本 B
var foo = '42'
foo
,而脚本 B 在当前作用域内定义变量 foo
。var
声明变量将会导致隐式的全局变量产生。// 全局作用域
var foo = 42;
function test() {
// 局部作用域
foo = 21;
}
test();
foo; // 21
test
内不使用 var
关键字声明 foo
变量将会覆盖外部的同名变量。
起初这看起来并不是大问题,但是当有成千上万行代码时,不使用 var
声明变量将会带来难以跟踪的 BUG。// 全局作用域
var items = [/* 数组 */];
for(var i = 0; i < 10; i++) {
subLoop();
}
function subLoop() {
// subLoop 函数作用域
for(i = 0; i < 10; i++) { // 没有使用 var 声明变量
// 干活
}
}
subLoop
之后就会终止,因为 subLoop
覆盖了全局变量 i
。
在第二个 for
循环中使用 var
声明变量可以避免这种错误。
声明变量时绝对不要遗漏 var
关键字,除非这就是期望的影响外部作用域的行为。局部变量
var
关键字声明。// 全局变量
var foo = 1;
var bar = 2;
var i = 2;
function test(i) {
// 函数 test 内的局部作用域
i = 5;
var foo = 3;
bar = 4;
}
test(10);
foo
和 i
是函数 test
内的局部变量,而对 bar
的赋值将会覆盖全局作用域内的同名变量。变量声明提升(Hoisting)
var
表达式和 function
声明都将会被提升到当前作用域的顶部。bar();
var bar = function() {};
var someValue = 42;
test();
function test(data) {
if (false) {
goo = 1;
} else {
var goo = 2;
}
for(var i = 0; i < 100; i++) {
var e = data[i];
}
}
var
表达式和 function
声明提升到当前作用域的顶部。// var 表达式被移动到这里
var bar, someValue; // 缺省值是 'undefined'
// 函数声明也会提升
function test(data) {
var goo, i, e; // 没有块级作用域,这些变量被移动到函数顶部
if (false) {
goo = 1;
} else {
goo = 2;
}
for(i = 0; i < 100; i++) {
e = data[i];
}
}
bar(); // 出错:TypeError,因为 bar 依然是 'undefined'
someValue = 42; // 赋值语句不会被提升规则(hoisting)影响
bar = function() {};
test();
var
表达式被从循环内移到外部,而且使一些 if
表达式更难看懂。if
表达式看起来修改了全部变量 goo
,实际上在提升规则被应用后,却是在修改局部变量。ReferenceError
。// 检查 SomeImportantThing 是否已经被初始化
if (!SomeImportantThing) {
var SomeImportantThing = {};
}
var
表达式会被提升到全局作用域的顶部。var SomeImportantThing;
// 其它一些代码,可能会初始化 SomeImportantThing,也可能不会
// 检查是否已经被初始化
if (!SomeImportantThing) {
SomeImportantThing = {};
}
// 译者注:来自 Nettuts+ 的一段代码,生动的阐述了 JavaScript 中变量声明提升规则
var myvar = 'my value';
(function() {
alert(myvar); // undefined
var myvar = 'local value';
})();
名称解析顺序
this
指向当前对象。arguments
,其中包含了传递到函数中的参数。foo
变量时,JavaScript 会按照下面顺序查找:
var foo
的定义。foo
名称的。foo
。
arguments
参数将会阻止原生的 arguments
对象的创建。命名空间
(function() {
// 函数创建一个命名空间
window.foo = function() {
// 对外公开的函数,创建了闭包
};
})(); // 立即执行此匿名函数
( // 小括号内的函数首先被执行
function() {}
) // 并且返回函数对象
() // 调用上面的执行结果,也就是函数对象
// 另外两种方式
+function(){}();
(function(){}());
结论
而且有利于程序的模块化。
发表评论
-
JavaScript Garden - instanceof 操作符
2011-03-31 23:59 1144instanceof 操作符 instanceof 操 ... -
JavaScript Garden - 该死的typeof 操作符
2011-03-31 23:58 1418typeof 操作符 typeof 操作符(和 ... -
JavaScript Garden - 类型转换
2011-03-31 23:55 957类型转换 JavaScript 是弱类型语言,所以会在任 ... -
JavaScript Garden - 相等与比较
2011-03-31 23:53 942相等与比较 JavaScript 有两种方式判断两个值是 ... -
JavaScript Garden - setTimeout 和 setInterval
2011-03-31 23:52 1342setTimeout 和 setInterval 由 ... -
JavaScript Garden - 为什么不要使用 eval
2011-03-31 23:50 1333为什么不要使用 eval eval 函数会在当前作用域 ... -
JavaScript Garden -自动分号插入
2011-03-31 23:48 1197自动分号插入 尽管 JavaScript 有 C 的代码 ... -
JavaScript Garden - undefined 和 null
2011-03-31 23:46 968undefined 和 null JavaScrip ... -
JavaScript Garden - Array 构造函数
2011-03-31 23:44 890Array 构造函数 由于 Array 的构造函数在如 ... -
JavaScript Garden - 数组遍历与属性
2011-03-31 23:43 1152数组遍历与属性 虽然在 JavaScript 中数组是是 ... -
JavaScript Garden - arguments 对象
2011-03-31 23:42 1107arguments 对象 JavaScript 中每个 ... -
JavaScript Garden - 闭包和引用
2011-03-31 23:39 1141闭包和引用 闭包是 JavaScript 一个非常重要的 ... -
JavaScript Garden - 构造函数
2011-03-31 23:38 905构造函数 JavaScript 中 ... -
JavaScript Garden - 函数声明与表达式
2011-03-31 23:36 911函数声明与表达式 函 ... -
JavaScript Garden - this 的工作原理
2011-03-31 23:35 930this 的工作原理 JavaScript 有一套完全 ... -
JavaScript Garden - for in 循环
2011-03-31 23:26 819for in 循环 和 in 操作符一样,for in ... -
JavaScript Garden - hasOwnProperty 函数
2011-03-31 23:25 1021hasOwnProperty 函数 为了判断一个对象 ... -
JavaScript Garden - 原型
2011-03-31 23:23 1003原型 JavaScript 不包含传统的类继承模型,而是 ... -
JavaScript Garden - 对象使用和属性
2011-03-31 23:22 856对象使用和属性 JavaScript 中所有变量都 ...
相关推荐
2. **函数**: 包括函数声明与表达式、`this`的工作原理、闭包与引用、`arguments`对象、构造函数、作用域与命名空间等内容,深入探讨了函数的灵活性和复杂性。 3. **数组**: 阐述了数组的遍历与属性、`Array`构造...
2. **函数**:声明函数、匿名函数、箭头函数、作用域和闭包。 3. **对象和数组**:对象字面量、构造函数、原型链、数组方法(如map、filter、reduce等)。 4. **DOM操作**:获取元素、添加/删除元素、事件处理。 5. ...
提示:jQuery 使用的语法是 XPath 与 CSS 选择器语法的组合。在本教程接下来的章节,您将学习到更多有关选择器的语法。 文档就绪函数 您也许已经注意到在我们的实例中的所有 jQuery 函数位于一个 document ready ...
# 基于OpenTelemetry的GPS设备监控项目 ## 项目简介 这是一个基于OpenTelemetry的GPS设备监控项目,旨在收集GPS设备的定位和运动数据,并通过OpenTelemetry协议发送到指定的接收端。本项目主要面向开发人员和对GPS监控感兴趣的用户。 ## 项目的主要特性和功能 1. 实时数据收集实时收集GPS设备的定位数据,包括经度、纬度、速度等信息。 2. 多传感器支持集成加速度计等其他传感器,收集更丰富的运动数据。 3. 数据传输通过OpenTelemetry协议将数据发送到接收端,支持多种数据传输方式。 4. 可视化界面具有可视化界面,可实时查看设备位置和运动数据。 5. 硬件兼容性支持多种硬件平台,具有良好的可扩展性和兼容性。 ## 安装使用步骤 1. 复制代码复制本项目代码并导入到Arduino或其他支持的微控制器开发环境。 2. 配置参数配置WiFi连接和OpenTelemetry接收端的参数。
网络安全:实验四:IKE实验(Cisco仿真-注意版本号,版本不一致打不开)
内容概要:本文详细介绍了模块化多电平变换器(MMC)在380V交流到800V直流转换中的仿真搭建过程及其关键技术。首先解释了MMC的基本原理,包括子模块的结构和工作方式。接着探讨了环流抑制的方法,通过模型预测控制和其他控制策略减少不必要的损耗和提高系统稳定性。此外,讨论了相间均能和电容均压的技术手段,确保系统的功率均衡和电压一致性。最后,描述了具体的仿真搭建步骤,包括电路拓扑的选择、参数设定、控制策略实现以及仿真结果分析。文中还提供了详细的仿真介绍文档和参考文献,帮助读者更好地理解和应用这些技术。 适合人群:电力电子领域的研究人员和技术人员,尤其是对MMC仿真感兴趣的初学者和有一定基础的研究者。 使用场景及目标:适用于希望深入了解MMC工作原理及其仿真技术的人群。主要目标是掌握MMC的仿真搭建方法,理解环流抑制、相间均能和电容均压等关键技术的应用,最终能够独立完成类似的仿真项目。 其他说明:文章不仅提供了理论知识,还包括了大量的代码示例和具体的操作指南,使读者能够在实践中验证所学内容。同时,提供的参考文献有助于进一步深入研究相关课题。
题目:非接触式转速测量仪 主控:STM32 显示屏:Oled 电机驱动:L298 电机(带编码器可测速的三线电机) 按键(增速或者减速等)
内容概要:本文详细介绍了基于MCU的固件加锁系统,涵盖上位机和设备端的实现细节。上位机部分使用C#和Python实现了多线程并行处理框架,能够高效地管理和监控多个设备的同时加锁操作。设备端代码采用C语言编写,实现了闪存写保护、状态机控制以及通信协议设计,确保加锁过程的安全性和可靠性。文中还讨论了硬件抽象层的移植性、通信协议的优化、密钥处理的安全措施等问题,并分享了实际应用中的经验和技巧。 适合人群:嵌入式系统开发人员、MCU固件工程师、硬件安全研究人员。 使用场景及目标:适用于需要批量处理固件加锁的生产环境,如智能锁具、水表等产品的生产线。目标是提供一种轻量级、高效的固件保护方案,防止未经授权的固件烧录和逆向工程。 其他说明:文中提供了详细的代码片段和技术细节,帮助读者理解和实现类似的固件加锁系统。强调了安全性、稳定性和易移植性的设计原则。
房地产培训 -物业客服礼仪培训.ppt
智慧城管,作为现代城市管理的新模式,正以其独特的魅力引领着城市管理方式的深刻变革。这一解决方案融合了物联网、云计算、大数据等前沿技术,为城市打造了一套高效、智能、全面的管理体系。 想象一下,城市的每一个角落都被智能感知设备所覆盖,从街道的监控摄像头到井盖下的传感器,它们就像城市的神经末梢,实时收集着城市运行的点点滴滴。这些数据通过高速网络汇聚到智慧城管平台,经过大数据分析处理,为管理者提供了精准的决策支持。无论是违规停车的自动抓拍,还是公共设施损坏的及时预警,智慧城管都能迅速响应,让城市管理变得更加主动、高效。 更令人兴奋的是,智慧城管不仅提升了管理效率,还极大地丰富了服务手段。市民可以通过手机APP一键上报问题,从路灯不亮到井盖丢失,各种问题都能得到快速处理。同时,智慧城管平台还整合了城市服务资源,如网上办事大厅、公共信息查询等,让市民享受到了更加便捷、高效的城市服务。此外,智慧城管还通过大数据分析,为城市规划、交通管理、环境保护等领域提供了科学依据,助力城市可持续发展。 总之,智慧城管综合解决方案以其先进的技术、丰富的功能和卓越的性能,为城市管理注入了新的活力。它不仅让城市管理变得更加智能、高效,还极大地提升了市民的幸福感和满意度。对于致力于提升城市管理水平的城市管理者来说,智慧城管无疑是一个值得深入研究和推广的解决方案。
# 基于C++编程语言的智能家居控制系统 ## 项目简介 本项目是一个基于C++编程语言的智能家居控制系统,旨在通过Arduino平台实现对家居设备的智能控制,包括气候控制、安全警报、门禁系统等功能。通过WiFi连接和MQTT协议,实现了对家中环境参数的监控和调整,以及通过RFID识别和MQTT消息处理实现基本的家居自动化功能。 ## 项目的主要特性和功能 1. 气候控制通过DHT传感器监控客厅、厨房和卧室的温度和湿度,并根据设定的目标值自动调整室内环境。 2. 安全警报通过红外人体感应器和磁传感器监测家中的异常情况,如入侵或门窗未关,并通过RGB灯和MQTT消息通知用户。 3. 门禁系统通过RFID识别和键盘输入实现身份验证,控制门的开启和关闭。 4. OLED显示在OLED屏幕上显示当前时间、温度、湿度等信息,提供用户友好的交互界面。 5. MQTT通信使用MQTT协议与服务器通信,实现消息的发布和订阅,便于远程控制和日志记录。
# 基于Spring Boot的数据交易平台 ## 项目简介 本项目是一个基于区块链技术的数据交易与鉴权平台,名为“DataMall”。它提供了一个安全、可靠的环境,用于数据的交易和鉴权,确保数据的完整性和安全性。平台采用Spring Boot作为后端开发框架,结合MyBatis Plus进行数据库操作,支持支付宝支付和阿里云OSS存储服务。 ## 项目的主要特性和功能 1. 用户管理包括用户注册、登录、找回密码、账号信息查询等功能。 2. 商品管理用户可以发布、修改、删除商品,管理员可以冻结或解冻商品。 3. 订单管理用户可以提交订单、支付订单,管理员可以查询订单详情。 4. 权限管理管理员可以管理角色和权限,确保系统的安全性和可控性。 5. 支付功能集成支付宝支付功能,支持用户在线支付。 6. 文件存储使用阿里云OSS进行文件存储,确保数据的安全性和可靠性。
内容概要:本文详细介绍了VIC水文模型的径流模拟方法,涵盖从环境搭建、数据预处理到模型参数率定的全过程。首先讲解了如何使用Python进行土壤分层、能量平衡计算以及产流计算的具体实现,接着分享了模型执行流程的关键步骤,如气象数据处理、参数配置和优化技巧。文中还提供了许多实际操作中的经验和技巧,帮助初学者避开常见陷阱。最后强调了模型可视化验证的重要性,并给出了具体的代码示例。 适合人群:对水文学感兴趣的研究人员、学生以及希望深入了解水文模型应用的技术爱好者。 使用场景及目标:适用于希望通过Python实现VIC水文模型径流模拟的学习者,旨在帮助他们掌握从理论到实践的完整流程,提高模型构建能力和数据分析水平。 其他说明:作者结合自身实践经验,提供了一系列实用的操作指南和技术细节,使读者能够更好地理解和应用VIC水文模型。
452047732824847酒店民宿预订管理系统(含12个月预订明细)1.xlsx
内容概要:本文详细介绍了如何复现2023年发表于《Science》的论文 'Extreme ultraviolet metalens by vacuum guiding' 中提出的极紫外超透镜设计。文章涵盖了硅-空气纳米柱结构的传输相位计算、理想相位分布的构建、FDTD仿真步骤及其结果分析。通过Matlab和Python代码示例,展示了如何计算不同纳米柱半径对应的传输相位,并利用FDTD仿真验证设计的有效性。此外,文中还讨论了仿真过程中遇到的问题及解决方法,如相位库构建、相位梯度约束、倏逝波修正等。 适合人群:从事光学、特别是极紫外光学领域的研究人员和技术人员,以及对超透镜设计感兴趣的科研工作者。 使用场景及目标:①理解和掌握极紫外超透镜的设计原理;②通过FDTD仿真验证设计方案;③拓展应用于其他极紫外光学器件的设计,如极紫外全息和涡旋光生成器。 其他说明:文章不仅提供了详细的代码示例,还分享了许多实用的仿真技巧和实践经验,有助于提高极紫外光学系统的性能。
内容概要:本文详细介绍了利用粒子群算法(PSO)在Matlab中设计宽带消色差超透镜的方法及其FDTD仿真验证。首先,通过定义合理的初始参数范围和适应度函数,将超透镜的纳米结构参数(如纳米柱的直径、高度、周期)作为粒子的位置,采用PSO进行优化。适应度函数结合了预存的相位延迟查找表和实时FDTD仿真结果,确保优化过程中能够高效评估不同结构参数的效果。文中还讨论了惯性权重的动态调整、震荡因子的引入以及适应度函数中物理约束的添加,以提高优化效果并防止陷入局部最优。最终,通过FDTD仿真验证优化结果,展示了在可见光波段内的聚焦效率和焦斑尺寸的改进。 适合人群:从事光学设计、超材料研究、电磁仿真领域的科研人员和技术开发者。 使用场景及目标:适用于需要设计高性能宽带消色差超透镜的研究项目,旨在通过粒子群算法优化超透镜结构参数,减少色差并提高聚焦效率。 其他说明:文中提供了详细的Matlab代码片段和FDTD仿真设置示例,帮助读者更好地理解和实施该方法。此外,强调了在实际应用中需要注意的参数选择和物理约束,以确保设计方案的可行性和有效性。
内容概要:本文详细介绍了700张道路裂纹语义分割数据集的构成及其应用场景。数据集采用VOC格式,包含原图、mask二值图和标注文件。文中提供了处理mask、标注以及数据集划分的方法,并讨论了如何将这些数据用于训练分割网络,如UNet。此外,还探讨了数据增强技术和损失函数的选择,以应对数据量不足和类别不平衡的问题。最后,介绍了滑动窗口预测方法,确保大尺寸图像的边缘处理更加平滑。 适合人群:从事计算机视觉、图像处理领域的研究人员和技术开发者,尤其是关注道路维护和安全监测的人群。 使用场景及目标:适用于需要进行道路裂纹检测的应用场景,如城市基础设施维护、自动驾驶车辆的安全检测等。主要目标是提高裂纹检测的准确性,优化模型性能,提升检测效率。 其他说明:文中提供的代码片段和技巧有助于初学者快速上手语义分割任务,同时也为经验丰富的研究者提供了优化模型的具体思路。
# 基于MSP430G2553微控制器的多功能应用平台 ## 项目简介 本项目是一个基于MSP430G2553微控制器的多功能平台。集成多种硬件模块,如超声波传感器、七段LED显示器、蓝牙通信、ESP8266 WiFi模块等,并提供对应驱动和函数库,用于实现复杂控制和应用。 ## 项目的主要特性和功能 1. 丰富的硬件接口借助MSP430G2553微控制器的GPIO、ADC、PWM等接口,与各类硬件模块通信和控制。 2. 模块化设计将硬件接口、驱动、应用等功能分离,便于扩展和维护。 3. 齐全的功能涵盖超声波距离测量、LED显示、蓝牙通信、WiFi连接等多种功能。 4. 高效的中断处理利用MSP430G2553的硬件中断处理功能,实现高效的数据接收和响应。 5. 数据处理优化使用环形缓冲区处理接收到的数据,提升数据处理效率。 6. 清晰的代码结构代码结构清晰,易于理解和修改,适合嵌入式系统开发。 ## 安装使用步骤
# 基于megaTiny和nRF24L01+的无线BootLoader ## 项目简介 本项目是一个基于megaTiny系列微控制器(如ATtiny1614)和nRF24L01+无线模块的BootLoader实现。它允许用户通过无线方式对嵌入式系统进行固件更新,适用于那些难以通过传统方式访问或更新固件的场景。 ## 项目的主要特性和功能 1. 无线固件更新通过nRF24L01+无线模块接收新的固件代码,并将其烧写到MCU的Flash内存中。 2. 小型化设计BootLoader代码占用空间小,适合资源有限的嵌入式系统。 3. 多设备支持支持多种megaTiny系列芯片,如ATtiny1614、ATtiny814等。 4. CRC校验使用内置的CRC硬件进行数据校验,确保固件更新的正确性。 5. API支持提供API供应用程序使用,方便集成和扩展。 6. Arduino兼容支持与Arduino开发环境的集成,方便开发者使用。 ## 安装使用步骤
Screenshot_2025-04-17-20-35-51-251_tv.danmaku.bili.jpg