Handler实现每n秒一次的无线循环

定义 Handler handler=new Handler();

 

定义Runnable runnable = new Runnable() {

@Override
public void run() {
// TODO Auto-generated method stub
handler.postDelayed(this, n);
Log.e("test", "wo are running!!!");
}
};

 

在onCreate()中,执行以下方法:

handler.postDelayed(runnable , n);

 

解释:

handler.postDelayed(runnable,n);//延迟n秒后,执行runnable线程。

 

因为在线程中,还会调用自己执行,所以形成了无线循环。

 

好的,我可以为您提供设计思路和代码示例。首先,我们需要了解一下 Systick 是什么。 Systick 是 ARM Cortex-M 系列处理器中的系统计时器,它可以提供一个固定的时钟频率,一般为处理器时钟频率的 1/8 或 1/10。通过对 Systick 计数器进行计数,可以实现定时功能。 我们可以使用 Systick 计时器来实现电子时钟的计时功能。具体实现步骤如下: 1. 设置 Systick 计时器的时钟源和计时周期:在 Cortex-M 处理器中,Systick 计时器的时钟源默认为处理器时钟,计时周期为 1ms。我们可以通过修改相关寄存器来改变时钟源和计时周期。在本例中,我们将时钟源和计时周期均设置为默认值。 2. 编写中断服务函数:Systick 计时器计数器每计满一次计时周期,就会触发一次中断。我们需要编写一个中断服务函数来响应该中断,并在其中更新时分的值。 3. 编写主函数:在主函数中,我们需要初始化串口和 Systick 计时器,并启用中断。然后进入一个无限循环,等待中断发生,每输出一次当前的时分信息。 下面是代码示例: ```c #include "stm32f10x.h" #include "stdio.h" volatile uint32_t tick = 0; // 计时器计数值 volatile uint32_t second = 0; // 数 void SysTick_Handler(void) { tick++; // 计数器加1 if (tick == 1000) // 如果计数器达到1000,说明已经过了1 { tick = 0; // 计数器清零 second++; // 数加1 } } void uart_init(void) { GPIO_InitTypeDef GPIO_InitStructure; USART_InitTypeDef USART_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_USART1, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOA, &GPIO_InitStructure); USART_InitStructure.USART_BaudRate = 115200; USART_InitStructure.USART_WordLength = USART_WordLength_8b; USART_InitStructure.USART_StopBits = USART_StopBits_1; USART_InitStructure.USART_Parity = USART_Parity_No; USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; USART_Init(USART1, &USART_InitStructure); USART_Cmd(USART1, ENABLE); } void systick_init(void) { SysTick_Config(SystemCoreClock / 1000); // 设置时钟源和计时周期 } int main(void) { char buf[50]; uint32_t hour = 0, minute = 0; uart_init(); systick_init(); NVIC_EnableIRQ(SysTick_IRQn); // 启用中断 while (1) { if (second >= 60) // 如果数达到60,说明已经过了1分钟 { second = 0; // 数清零 minute++; // 分钟数加1 } if (minute >= 60) // 如果分钟数达到60,说明已经过了1小时 { minute = 0; // 分钟数清零 hour++; // 小时数加1 } sprintf(buf, "%02d:%02d:%02d\r\n", hour, minute, second); // 格式化输出时分 USART_SendString(USART1, buf); // 通过串口输出时分 } } ``` 注意,本例中的 USART_SendString 是一个自定义的函数,用于通过串口发送字符串。您需要根据自己的硬件环境和串口配置来修改该函数。 另外,本例中的时钟频率为 72MHz,Systick 计时周期为 1ms,因此每钟会触发 1000 次中断。如果您的时钟频率或 Systick 计时周期不同,需要相应地修改代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值