C语言 实现监听 原理,[转]Java监听器的原理与实现

监听器是一个专门用于对其他对象身上发生的事件或状态改变进行监听和相应处理的对象,当被监视的对象发生情况时,立即采取相应的行动。

监听器其实就是一个实现特定接口的普通java程序,这个程序专门用于监听另一个java对象的方法调用或属性改变,当被监听对象发生上述事件后,监听器某个方法立即被执行。

我们是写监听器去监听其他对象,那么我们如果想设计一个对象,让这个对象可以被别的对象监听又该怎么做呢,

可以按照严格的事件处理模型来设计一个对象,这个对象就可以被别的对象监听,事件处理模型涉及到三个组件:事件源、事件对象、事件监听器。

模型图

监听器模型涉及以下三个对象,模型图如下:

(1)事件:用户对组件的一个操作,称之为一个事件

(2)事件源:发生事件的组件就是事件源

(3)事件监听器(处理器):监听并负责处理事件的方法

aca3d7d358dfc3553745691f1fe75708.png

执行顺序如下

1、给事件源注册监听器

2、组件接受外部作用,也就是事件被触发

3、组件产生一个相应的事件对象,并把此对象传递给与之关联的事件处理器

4、事件处理器启动,并执行相关的代码来处理该事件。

监听器模式

事件源注册监听器之后,当事件源触发事件,监听器就可以回调事件对象的方法;更形象地说,监听者模式是基于:注册-回调的事件/消息通知处理模式,就是被监控者将消息通知给所有监控者。

1、注册监听器:事件源.setListener;

2、回调:事件源实现onListener。

下面,来看两个demo。

一、简化了上图所示的模型,仅仅包含事件源与监听器

/*

* 事件源:事件发生的地点

*/

public class EventSource

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
BMS(Battery Management System,电池管理系统)中,SOC(State of Charge,充电状态)算法是用于估算电池当前剩余电量的算法。常见的SOC算法有五种,分别是开路电压法、安时积分法、卡尔曼滤波法、神经网络法和等效电路法。下面分别介绍这五种算法的C语言实现原理讲解。 1. 开路电压法 开路电压法是通过电池开路电压(OCV)来估算电池SOC的方法。具体实现时,需要根据电池的开路电压曲线制定对应的SOC曲线,然后根据当前电池的开路电压来查找相应的SOC值。 ```c #include <stdio.h> float map(float x, float in_min, float in_max, float out_min, float out_max) { return (x - in_min) * (out_max - out_min) / (in_max - in_min) + out_min; } int main() { float ocv, soc; ocv = 12.5; // 模拟获取电池开路电压 // 根据开路电压和SOC曲线计算SOC值 if (ocv >= 4.18) { soc = map(ocv, 4.18, 4.2, 95, 100); } else if (ocv >= 4.1) { soc = map(ocv, 4.1, 4.18, 85, 95); } else if (ocv >= 4.0) { soc = map(ocv, 4.0, 4.1, 65, 85); } else if (ocv >= 3.9) { soc = map(ocv, 3.9, 4.0, 35, 65); } else if (ocv >= 3.8) { soc = map(ocv, 3.8, 3.9, 10, 35); } else { soc = 0; } printf("SOC: %.2f%%\n", soc); // 输出SOC值 return 0; } ``` 2. 安时积分法 安时积分法是通过电池的充放电电流来估算电池SOC的方法。具体实现时,需要将电池的充放电电流进行安时积分,得到电池的累计电量,然后将累计电量除以电池的额定电量,即可得到电池的SOC。 ```c #include <stdio.h> #include <time.h> int main() { float current, capacity = 0, rated_capacity = 10; // 假设电池额定电量为10Ah time_t start_time, end_time; double time_interval; // 获取当前时间 start_time = time(NULL); // 模拟获取电流值 current = 2.5; // 计算电量 time(&end_time); time_interval = difftime(end_time, start_time); // 计算时间间隔 capacity += current * time_interval / 3600; // 将电量累加到总电量中 // 计算SOC float soc = capacity / rated_capacity * 100; printf("SOC: %.2f%%\n", soc); // 输出SOC值 return 0; } ``` 3. 卡尔曼滤波法 卡尔曼滤波法是一种通过状态估计的方法来估算电池SOC的方法。具体实现时,需要将电池的电压、电流和温度等状态作为输入,然后使用卡尔曼滤波算法对电池的SOC进行估计。 ```c // 卡尔曼滤波法的C语言实现比较复杂,此处不再给出示例代码。 ``` 4. 神经网络法 神经网络法是一种通过训练神经网络来估算电池SOC的方法。具体实现时,需要将电池的输入状态作为神经网络的输入,将电池的SOC作为神经网络的输出,然后通过大量的数据进行训练,得到一个能够准确估算电池SOC的神经网络模型。 ```c // 神经网络法的C语言实现比较复杂,此处不再给出示例代码。 ``` 5. 等效电路法 等效电路法是通过建立电池的等效电路模型来估算电池SOC的方法。具体实现时,需要将电池的等效电路模型分为若干个电路模块,然后根据电池的输入状态和电路模块参数计算电池的SOC。 ```c // 等效电路法的C语言实现比较复杂,此处不再给出示例代码。 ``` 以上是五种常见的BMS SOC算法的C语言实现原理讲解,具体实现时需要根据您的具体需求进行修改和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值