变量使用--绑定时间

本文介绍了三种不同的变量绑定时机:编写代码时、编译程序时及运行时,并对比了硬编码与具名常量等不同方法的优劣。此外还探讨了对象实例化时绑定变量的应用场景。

所谓绑定时间就是把变量和它的值绑定在一起的时间。

编写代码时绑定

 

titleBar.color = 0xFF;//0xFF is hex value for color blue

 由于0xFF是硬编码(hard-coded)在程序里的数值,在编写代码的时候它就会绑定到titleBar.color变量上。这种硬编码技术通常是很糟糕的,因为一旦要修改这个0xFF,那么这个新值就无法同代码中其他那些必须和它一样的0xFF值保持一致了。

 

编译程序时绑定

private static final int COLOR_BLUE = 0xFF;
private static final int TITLE_BAR_COLOR = COLOR+BULE;
....

 titleBar.color = TITLE_BAR_COLOR;
TITLE_BAR_COLOR是一个具名常量,编译器会在编译时把它替换成一个数值。如果你用的语言支持这种特性,那么这种方法几乎总是要好于硬编码。
由于TITLE_BAR_COLOR比0xFF更能反映出所代表的信息,因此增加了可读性。它也能使修改标题栏颜色变得更容易,因为一处改动就能对所有位置生效。同时也不会影响运行期的性能。

 

运行时绑定

titleBar.color = ReadTitleBarColor();

 ReadTitleBarColor()是一个能在程序运行期间读入数值的子程序,数值来源可能是配置文件,也可能来自spring的注入。
与硬编码相比,这样的代码更具可读性和灵活性。无须通过修改程序来改变titleBar.color,只要简单修改ReadTitleColor()子程序要读取的数据源内容即可。

 

对象实例化时绑定

public TitleBar ConstructTitleBar(Config config){
	...
	titleBar.color = config.ReadTitleBarColor();
	...
	return titleBar;
}

 ConstructTitleBar()是一个能在对象实例化的时候通过配置中相应的方法来设置color。

【轴承故障诊断】加权多尺度字典学习模型(WMSDL)及其在轴承故障诊断上的应用(Matlab代码实现)内容概要:本文介绍了加权多尺度字典学习模型(WMSDL)在轴承故障诊断中的应用,并提供了基于Matlab的代码实现。该模型结合多尺度分析字典学习技术,能够有效提取轴承振动信号中的故障特征,提升故障识别精度。文档重点阐述了WMSDL模型的理论基础、算法流程及其在实际故障诊断中的实施步骤,展示了其相较于传统方法在特征表达能力和诊断准确性方面的优势。同时,文中还提及该资源属于一个涵盖多个科研方向的技术合集,包括智能优化算法、机器学习、信号处理、电力系统等多个领域的Matlab仿真案例。; 适合人群:具备一定信号处理和机器学习基础,从事机械故障诊断、工业自动化、智能制造等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①学习并掌握加权多尺度字典学习模型的基本原理实现方法;②将其应用于旋转机械的轴承故障特征提取智能诊断;③结合实际工程数据复现算法,提升故障诊断系统的准确性和鲁棒性。; 阅读建议:建议读者结合提供的Matlab代码进行实践操作,重点关注字典学习的训练过程多尺度分解的实现细节,同时可参考文中提到的其他相关技术(如VMD、CNN、BILSTM等)进行对比实验算法优化。
### 实现 UniApp 中 `uni-datetime-picker` 默认显示当前日期 在 UniApp 的开发环境中,可以通过设置 `value` 属性来指定 `uni-datetime-picker` 组件的默认值。为了使该组件默认显示当前日期,可以利用 JavaScript 获取当前的时间戳并将其传递给组件。 以下是具体的实现方式: #### 示例代码 ```javascript <template> <view> <!-- 使用 uni-datetime-picker --> <uni-datetime-picker type="daterange" :start="startDate" :end="endDate" v-model="selectedDateRange" @change="onDateChange"> </uni-datetime-picker> </view> </template> <script> export default { data() { return { selectedDateRange: [], // 存储用户选择的时间范围 startDate: '', // 起始时间 endDate: '' // 结束时间 }; }, created() { this.setDefaultValue(); }, methods: { setDefaultValue() { const now = new Date(); // 当前时间对象 const year = now.getFullYear(); const month = String(now.getMonth() + 1).padStart(2, '0'); const day = String(now.getDate()).padStart(2, '0'); // 构造当天日期字符串 const today = `${year}-${month}-${day}`; // 将起始时间和结束时间均设为今天 this.startDate = today; this.endDate = today; // 如果需要,默认选中今天的日期范围 this.selectedDateRange = [today, today]; }, onDateChange(e) { console.log('Selected date range:', e); } } }; </script> ``` --- #### 关键点解析 1. **获取当前日期** 利用 `new Date()` 方法创建当前时间对象,并通过 `.getFullYear()`、`.getMonth()` 和 `.getDate()` 提取年份、月份和日数[^1]。注意月份是从零开始计数的,因此需加一处理。 2. **格式化日期** 使用 `String().padStart(2, '0')` 确保月份和日期始终为两位数形式,从而满足标准日期格式的要求。 3. **绑定默认值** 在组件初始化阶段调用 `setDefaultValue` 方法,将 `startDate` 和 `endDate` 均设置为当前日期。如果希望默认选中某个时间段,则可以直接赋值给 `v-model` 所绑定的数据变量 `selectedDateRange`。 4. **事件监听** 添加 `@change` 事件用于捕获用户的操作行为,并打印所选的时间范围以便调试或进一步处理。 --- #### 注意事项 - 若仅需单个日期而非区间,可将 `type` 属性改为 `"date"` 并调整数据结构。 - 验证逻辑可根据实际业务需求扩展,例如参照引用中的校验函数[^3]。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值