随记

1、最简单的死循环
	for(;;){}
2、 var arr = [33,5,8,5,2,6]
	for(i in arr){
		alert(i)    // 下标   0 1 2 3 4 5
		alert(arr[i]) // 值  33 5 8 5 2 6
	}
3、break
	单独使用break语句的作用是立即退出最内层的循环或switch语句。
	JS中同样允许break关键字后面跟随一个语句标签(只有标识符,没有冒号)。程序将跳转到这个标签所标识的语句块的结束。
	break labelname;
4、continue语句和break语句类似。
	在不同类型的循环中,continue的行为也有所区别:
		在while循环中,在循环开始处指定的expression会重复检测,如果检测结果为true,循环体会从头开始执行;
		在do/while循环中,程序的执行直接跳到循环结尾处,这时会重新判断循环条件,之后才会继续下一次循环;
		在for循环中,首先计算自增表达式,然后再次检测test表达式,泳衣判断是否执行循环体。
		在for/in循环中,循环开始遍历下一个属性名,这个属性名赋给了指定的变量。
5、数组直接量的语法允许有可选的结尾的逗号
	[,,]只有两个元素而非三个
6、数组的索引是基于零的32位数值
	0 ~ (2^32-2)
7、可以使用负数或非整数来索引数组,这种情况下,数值转换为字符串,字符串作为属性名来用,而非数组的索引。
如果使用了非负整数的字符串,它就当做数组索引,而非对象属性。
8、Object.prototype.toString.call(obj)返回对象的数据类型
	格式为 "[object Array]"  字符串类型
	通过 .slice(8,-1) 截取字符串得到数据类型。

9、数组创建方式
	var a1 = [,,,] 		数组是[undefined,undefined,undefined]
	var a2 = [undefined];
	var a3 = new Array(3)	数组根本没有元素
	alert(0 in a1); 	false
	alert(0 in a2);		true
	alert(0 in a3);		false
10、数组的length属性
	arr.length = 0 会改变原数组
	可以用Object.defineProperty()让数组的length属性变成只读属性
		var a = [1,2,3]
		Object.defineProperty(a, 'length', {writable: false})
		a.length = 0   a不会改变
11、可以像删除对象属性一样使用delete运算符来删除数组元素
	var a = [1,2,3]
	delete a[1]
	// a[1] = null
	alert(a) 	// 1,,3
	alert(a.length) // delete操作并不影响数组长度
	alert(1 in a) //false, 数组索引1并未在数组中定义

12、数组遍历优化
	for(var i=0;i<arr.length;i++){}
	for(var i=0, len=arr.length;i<len;i++){}

	当数组可能是稀疏数组时,使用数组元素之前应该先检测它们,
		若想排除null, undefined和不存在的元素
			for(var i=0;i<arr.length;i++){
				if(!arr[i]) continue;  // 跳过null, undefined和不存在的元素
			}
		若只想跳过undefined和不存在的元素
			for(var i=0;i<arr.length;i++){
				if(arr[i] === undefined) continue;  // 跳过undefined和不存在的元素
			}
		若只想跳过不存在的元素而仍然要处理存在的undefined元素
			for(var i=0;i<arr.length;i++){
				if(!(i in arr)) continue;  // 跳过undefined和不存在的元素
			}

13、ECMA5定义了一些遍历数组元素的新方法,按照索引的顺序传递给定义的函数,如  forEach()方法
	var data = [1,2,3,4,5]
	data.forEach(function(x){
		......
	})

14、排列字符串数组
	a = ['ant', 'Bug', 'cat', 'Dog'];
	a.sort(); 		//区分大小写的排序:['Bug', 'Dog', 'ant', 'ant', ]
	a.sort(function(s,t){ 	// 不区分大小写的排序:ant,Bug,cat,Dog
		var a = s.toLowerCase();
		var b = t.toLowerCase();
		if(a < b) return -1;
		if(a > b) return 1;
	})

15、数组操作concat()
	var a = [1,2,3]
	a.concat(4,[5,[6,7]]) // [1, 2, 3, 4, 5, [6,7]]

16、toString()
	针对数组,该方法将其每个元素转化为字符串(如有必要将调用元素的toString()方法),并且输出用逗号分隔的字符串系列。注意,输出不包括方括号或其他任何形式的包裹数组值的分隔符。与不加任何参数的.join()方法类似;
	[1,2,3].toString() 		生成'1,2,3'
	['a','b','c'].toString() 生成'a,b,c'
	[1,[2,'c']].toString() 	生成'1,2,c'

  

C语言-光伏MPPT算法:电导增量法扰动观察法+自动全局搜索Plecs最大功率跟踪算法仿真内容概要:本文档主要介绍了一种基于C语言实现的光伏最大功率点跟踪(MPPT)算法,结合电导增量法与扰动观察法,并引入自动全局搜索策略,利用Plecs仿真工具对算法进行建模与仿真验证。文档重点阐述了两种经典MPPT算法的原理、优缺点及其在不同光照和温度条件下的动态响应特性,同时提出一种改进的复合控制策略以提升系统在复杂环境下的跟踪精度与稳定性。通过仿真结果对比分析,验证了所提方法在快速性和准确性方面的优势,适用于光伏发电系统的高效能量转换控制。; 适合人群:具备一定C语言编程基础和电力电子知识背景,从事光伏系统开发、嵌入式控制或新能源技术研发的工程师及高校研究人员;工作年限1-3年的初级至中级研发人员尤为适合。; 使用场景及目标:①掌握电导增量法与扰动观察法在实际光伏系统中的实现机制与切换逻辑;②学习如何在Plecs中搭建MPPT控制系统仿真模型;③实现自动全局搜索以避免传统算法陷入局部峰值问题,提升复杂工况下的最大功率追踪效率;④为光伏逆变器或太阳能充电控制器的算法开发提供技术参考与实现范例。; 阅读建议:建议读者结合文中提供的C语言算法逻辑与Plecs仿真模型同步学习,重点关注算法判断条件、步长调节策略及仿真参数设置。在理解基本原理的基础上,可通过修改光照强度、温度变化曲线等外部扰动因素,进一步测试算法鲁棒性,并尝试将其移植到实际嵌入式平台进行实验验证。
【无人机协同】动态环境下多无人机系统的协同路径规划与防撞研究(Matlab代码实现)​ 内容概要:本文围绕动态环境下多无人机系统的协同路径规划与防撞问题展开研究,提出基于Matlab的仿真代码实现方案。研究重点在于在复杂、动态环境中实现多无人机之间的高效协同飞行与避障,涵盖路径规划算法的设计与优化,确保无人机集群在执行任务过程中能够实时规避静态障碍物与动态冲突,保障飞行安全性与任务效率。文中结合智能优化算法,构建合理的成本目标函数(如路径长度、飞行高度、威胁规避、转弯角度等),并通过Matlab平台进行算法验证与仿真分析,展示多机协同的可行性与有效性。; 适合人群:具备一定Matlab编程基础,从事无人机控制、路径规划、智能优化算法研究的科研人员及研究生。; 使用场景及目标:①应用于灾害救援、军事侦察、区域巡检等多无人机协同任务场景;②目标是掌握多无人机系统在动态环境下的路径规划与防撞机制,提升协同作业能力与自主决策水平;③通过Matlab仿真深入理解协同算法的实现逻辑与参数调优方法。; 阅读建议:建议结合文中提供的Matlab代码进行实践操作,重点关注目标函数设计、避障策略实现与多机协同逻辑,配合仿真结果分析算法性能,进一步可尝试引入新型智能算法进行优化改进。
先展示下效果 https://pan.quark.cn/s/a4b39357ea24 StudentInfo 基于SSM的学生信息管理系统(选课) 已停更 项目简介: 由SpringMVC+MyBatis为主要框架,mysql8.0配置主从复制实现读写分离,主机丛机分别为腾讯云的服务器,而项目部署在阿里云上。 前端主要由bootstrap完成,背景用particles.js插件。 数据库交互查询用到pagehelper分页。 在添加修改相关功能时通过ajax来验证其主键是否存在可用。 代码层次清晰,输入框约束较高,已配置登录拦截。 一、应用技术 #### 工具:eclipse、navicat 环境:JDK1.8、tomcat9.0、mysql8.0 前端:JavaScript、jQuery、bootstrap4、particles.js 后端:maven、SpringMVC、MyBatis、ajax、mysql读写分离、mybatis分页 二、功能 #### 这是在上个springmvc选课系统的基础上进行修改完善的,目前功能基本相同,修复诸多bug,上个系统中有详细介绍:B/S基于springMVC的网上选课系统 主要功能模块图: 新增: 增加分页查询 输入框约束 学号、身份证、课程编号、教师编号只能输入数字,并且有最大输入限制,其中学号固定12位,若小于12位将会有提示。 姓名只能输入中文。 几乎所有输入框不能输入空格等约束 下拉框联动 添加、修改课程采用二级联动,即所属系别——所属专业; 添加、修改学生采用三级联动,即系别——专业——班级。 (三级联动代码有些复杂,因为JavaScript学的不好=-=)。 ajax+springmvc验证 用于验证学号、课程编号、教师...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值