定时器分为软件定时器和硬件定时器。顾名思义,软件定时器就是有操作系统提供的软件定时器,硬件定时器就是用硬件芯片提供的定时器。

而在RT-Thread操作系统提供的定时器是软件定时器,但是为了便于管理,也分了硬件定时器和软件定时器(都属于上面的软件定时器)。

RT-Thread中的HARD_TIMER与SOFT_TIMER最大区别就是指向超时函数的执行位置不同,HARD_TIMER超时函数在中断上下文环境中执行,SOFT_TIMER超时函数在定时器线程上下文中执行。

下面代码将会创建两个静态定时器单次触发和周期触发

static struct rt_timer timer1; // 加上static限定只能在本文件
static struct rt_timer timer2;
static int cnt = 0; static void timer_out1(void *parameter)
{
rt_kprintf("periodic timer is timeout %d\n", cnt);
if(cnt++ >= 9)
{
rt_timer_stop(&timer1);
rt_kprintf("periodic timer was stop!\n");
}
} static void timer_out2(void *parameter)
{
rt_kprintf("one shot timer was stop!\n"); } static void timer_sample4(void) //加上void,养成好的代码习惯
{
rt_timer_init(&timer1, "timer1", timer_out1, RT_NULL, 10, RT_TIMER_FLAG_PERIODIC);
rt_timer_start(&timer1);
rt_timer_init(&timer2, "timer2", timer_out2, RT_NULL, 30, RT_TIMER_FLAG_ONE_SHOT);
rt_timer_start(&timer2);
}
MSH_CMD_EXPORT(timer_sample4, timer_active);

  此时仿真时能够正常执行,但是下面这个代码会报错。

static rt_timer_t timer1; // 加上static限定只能在本文件
static rt_timer_t timer2;
static int cnt = 0; static void timer_out1(void *parameter)
{
rt_kprintf("periodic timer is timeout %d\n", cnt);
if(cnt++ >= 9)
{
rt_timer_stop(timer1);
rt_kprintf("periodic timer was stop!\n");
}
} static void timer_out2(void *parameter)
{
rt_kprintf("one shot timer was stop!\n"); } static void timer_sample4(void) //加上void,养成好的代码习惯
{
rt_timer_init(timer1, "timer1", timer_out1, RT_NULL, 10, RT_TIMER_FLAG_PERIODIC);
rt_timer_start(timer1);
rt_timer_init(timer2, "timer2", timer_out2, RT_NULL, 30, RT_TIMER_FLAG_ONE_SHOT);
rt_timer_start(timer2);
}
MSH_CMD_EXPORT(timer_sample4, timer_active);

  我猜想是因为结构体指针不是一个对象,只是一个能够指向结构体对象的指针。后来用下面这段代码进行了测试,验证猜想正确。

static struct rt_timer timer1; // 加上static限定只能在本文件
static struct rt_timer timer2;
static rt_timer_t timer3; // 加上static限定只能在本文件
static rt_timer_t timer4;
static int cnt = 0; static void timer_out1(void *parameter)
{
rt_kprintf("periodic timer is timeout %d\n", cnt);
if(cnt++ >= 9)
{
rt_timer_stop(&timer1);
rt_kprintf("periodic timer was stop!\n");
}
} static void timer_out2(void *parameter)
{
rt_kprintf("one shot timer was stop!\n"); } static void timer_sample4(void) //加上void,养成好的代码习惯
{
timer3 = &timer1;
timer4 = &timer2;
rt_timer_init(timer3, "timer1", timer_out1, RT_NULL, 10, RT_TIMER_FLAG_PERIODIC);
rt_timer_start(&timer1);
rt_timer_init(timer4, "timer2", timer_out2, RT_NULL, 30, RT_TIMER_FLAG_ONE_SHOT);
rt_timer_start(&timer2);
}
MSH_CMD_EXPORT(timer_sample4, timer_active);

  如果有错误,欢迎在评论区指正。

RT-Thread定时器以及结构体指针的一些思考的更多相关文章

  1. C与指针(结构体指针,函数指针,数组指针,指针数组)定义与使用

    类型 普通指针 指针数组(非指针类型) 数组指针 结构体指针 函数指针 二重指针 定义方式 int *p; int *p[5]; int (*p)[5]; int a[3][5]; struct{.. ...

  2. ctypes 操作 python 与 c++ dll 互传结构体指针

    CMakeLists.txt # project(工程名) project(blog-3123958139-1) # add_library(链接库名称 SHARED 链接库代码) add_libra ...

  3. python 传递结构体指针到 c++ dll

    CMakeLists.txt # project(工程名) project(xxx) # add_library(链接库名称 SHARED 链接库代码) add_library(xxx SHARED ...

  4. 【C语言入门教程】7.3 结构体指针的定义和引用

    C 语言中指针的操作非常灵活,它也能指向结构体变量对结构体变量进行操作.在学习结构指针之前,需要再次加深对指针的认识.声明指针变量时所使用的数据类型修饰符实际上的作用是定义指针访问内存的范围,如果指针 ...

  5. Delphi 中的结构体与结构体指针

    好多程序都给结构体变量设定了一个结构体指针 例如: PAbc = ^TAbc; TAbc = record a: string[10]; b: string[5]; c: string[1]; end ...

  6. (三)结构体指针、sizeof

    (一)结构体指针定义 今天上班写了一段测试代码,结果在linux下编译出现段错误,刚开始一直找不到原因,后来找了度娘才搞懂了.我先贴出来第一次写的代码以及gcc编译器下报的错误: #include&l ...

  7. c语言结构体指针初始化

    今天来讨论一下C中的内存管理. 记得上周在饭桌上和同事讨论C语言的崛起时,讲到了内存管理方面 我说所有指针使用前都必须初始化,结构体中的成员指针也是一样 有人反驳说,不是吧,以前做二叉树算法时,他的左 ...

  8. c语言中的结构体指针类型的cast

    1.我们在c语言中会经常碰到强制类型转换. 在这,我介绍一种结构pointer类型转换,但是有前提(有点类似于c++中的继承中的子父对象的cast). 简单的介绍一下: 首先我们要知道一个结构的指针, ...

  9. C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com

    原文:C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | I ...

随机推荐

  1. Emgu-WPF学习使用 - 颜色映射

    原文:Emgu-WPF学习使用 - 颜色映射 string sFile = ""; if (!String.IsNullOrEmpty(AppConstUtils.GDefault ...

  2. 高性能mysql笔记 第一章 mysql架构

    1.1  mysql逻辑结构 第一层: 负责连接处理,授权认证,安全等事情 第二层:负责mysql的大部分核心功能 ,查询解析,分析,优化,缓存和所有的内置函数,所有跨存储引擎的功能都在这一层实现,, ...

  3. jquery动态创建元素

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

  4. 通通WPF随笔(2)——自己制作轻量级asp.net网站服务

    原文:通通WPF随笔(2)--自己制作轻量级asp.net网站服务 大学玩asp.net时就发现VS在Debug时会起一个web服务,这东西也太神奇了服务起得这么快,而相对于IIS又这么渺小. 前几个 ...

  5. surfaceview组件的surfaceCreated()不被调用的解决方案

    原文:surfaceview组件的surfaceCreated()不被调用的解决方案 有时候我们有需要在native层做在surfaceview的上下文中做渲染,这个时候只是提供了一个单独什么都不做的 ...

  6. AY写给国人的教程- VS2017 Live Unit Testing[2/2]-C#人爱学不学-aaronyang技术分享

    原文:AY写给国人的教程- VS2017 Live Unit Testing[2/2]-C#人爱学不学-aaronyang技术分享 谢谢大家观看-AY的 VS2017推广系列 Live Unit Te ...

  7. Windows证书的生成导出以及使用证书验证文件是否被修改

    本文介绍了如何使用Windows自带的证书生成器生成,导出,使用证书.并以验证文件是否被修改举例 1.证书相关辅助类 public sealed class DataCertificate { #re ...

  8. 2018-4-25-- 2.在sublime3里安装git插件并连接GitHub

    1.配置全局参数 Git的主要配置包括用户名.邮箱的设置.以及生成SSH密钥公钥等. 首先运行一下的命令设置git提交代码时自己的用户信息. 2.在sublime3里使用时需要配置push.defau ...

  9. Linux下获取arm的交叉编译工具链

    转载请注明文章:Linux下获取arm的交叉编译工具链 出处:多客博图 这里介绍,Linux下获取arm的交叉编译工具链,比如arm-linux-gnueabihf-gcc.arm-linux-gne ...

  10. SQL Server修改标识列方法(备忘)

    原文:SQL Server修改标识列方法(备忘) SQL Server修改标识列方法 ----允许对系统表进行更新 exec sp_configure 'allow updates',1 reconf ...