#include <stdio.h>
#include <signal.h>
#include <unistd.h>
#include <sys/mman.h>

#include <native/task.h>
#include <native/timer.h>

RT_TASK demo_task;

/* NOTE: error handling omitted. */

void demo(void *arg)
{
    RTIME now, previous;

/*
     * Arguments: &task (NULL=self),
     *            start time,
     *            period (here: 1 ms)
     */
    rt_task_set_periodic(NULL, TM_NOW, 1000000);
    previous = rt_timer_read();

while (1) {
        rt_task_wait_period(NULL);
        now = rt_timer_read();

/*
         * NOTE: printf may have unexpected impact on the timing of
         *       your program. It is used here in the critical loop
         *       only for demonstration purposes.
         */
        printf("Time since last turn: %ld.%06ld ms\n",
               (long)(now - previous) / 1000000,
               (long)(now - previous) % 1000000);
               previous = now;
    }
}

void catch_signal(int sig)
{
}

int main(int argc, char* argv[])
{
    signal(SIGTERM, catch_signal);
    signal(SIGINT, catch_signal);

/* Avoids memory swapping for this program */
    mlockall(MCL_CURRENT|MCL_FUTURE);

/*
     * Arguments: &task,
     *            name,
     *            stack size (0=default),
     *            priority,
     *            mode (FPU, start suspended, ...)
     */
    rt_task_create(&demo_task, "trivial", 0, 99, 0);

/*
     * Arguments: &task,
     *            task function,
     *            function argument
     */
    rt_task_start(&demo_task, &demo, NULL);

pause();

rt_task_delete(&demo_task);

return 0;
}

2 测试结果:

Time since last turn: 0.997940 ms                                               
Time since last turn: 1.001939 ms                                               
Time since last turn: 0.996909 ms                                               
Time since last turn: 1.000727 ms                                               
Time since last turn: 1.003576 ms                                               
Time since last turn: 1.000606 ms                                               
Time since last turn: 0.998909 ms                                               
Time since last turn: 0.998243 ms                                               
Time since last turn: 1.001333 ms                                               
Time since last turn: 0.997636 ms                                               
Time since last turn: 1.003152 ms                                               
Time since last turn: 0.996788 ms                                               
Time since last turn: 1.000060 ms                                               
Time since last turn: 0.998667 ms                                               
Time since last turn: 1.005030 ms                                               
Time since last turn: 0.995031 ms                                               
Time since last turn: 1.002545 ms                                               
Time since last turn: 1.002303 ms                                               
Time since last turn: 0.995515 ms                                               
Time since last turn: 1.002849 ms                                               
Time since last turn: 0.997878 ms                                               
Time since last turn: 1.002000 ms                                               
Time since last turn: 0.998546 ms                                               
Time since last turn: 0.999576 ms                                               
Time since last turn: 1.002363 ms                                               
Time since last turn: 0.998425 ms                                               
Time since last turn: 0.998969 ms                                               
Time since last turn: 1.000061 ms                                               
Time since last turn: 1.002788 ms                                               
Time since last turn: 0.996848 ms                                               
Time since last turn: 1.002182 ms                                               
Time since last turn: 0.999212 ms                                               
Time since last turn: 1.001455 ms                                               
Time since last turn: 0.997636 ms                                               
Time since last turn: 1.004546 ms                                               
Time since last turn: 0.995757 ms                                               
Time since last turn: 1.000788 ms                                               
Time since last turn: 0.998485 ms                                               
Time since last turn: 1.001333 ms                                               
Time since last turn: 0.998485 ms                                               
Time since last turn: 1.001152 ms                                               
Time since last turn: 0.999878 ms                                               
Time since last turn: 0.999334 ms                                               
Time since last turn: 1.002121 ms                                               
Time since last turn: 0.999697 ms                                               
Time since last turn: 1.000242 ms                                               
Time since last turn: 0.997697 ms                                               
Time since last turn: 1.000303 ms                                               
Time since last turn: 0.999879 ms                                               
Time since last turn: 1.000788 ms                                               
Time since last turn: 1.000061 ms                                               
Time since last turn: 0.999636 ms                                               
Time since last turn: 1.001454 ms                                               
Time since last turn: 0.997334 ms                                               
Time since last turn: 1.004666 ms                                               
Time since last turn: 0.996910 ms                                               
Time since last turn: 1.002545 ms                                               
Time since last turn: 0.996485 ms                                               
Time since last turn: 1.001273 ms                                               
Time since last turn: 0.998666 ms                                               
Time since last turn: 1.000788 ms                                               
Time since last turn: 0.999758 ms                                               
Time since last turn: 1.000242 ms                                               
Time since last turn: 0.999091 ms                                               
Time since last turn: 1.002909 ms                                               
Time since last turn: 1.000485 ms                                               
Time since last turn: 0.996424 ms                                               
Time since last turn: 1.001818 ms

linux - native task api 测试的更多相关文章

  1. API 测试的具体实现

    目录 API 测试的具体实现 基于 Spring Boot 构建的 API 使用 cURL 命令行工具进行测试 使用图形界面工具 Postman 进行测试 如何应对复杂场景的 API 测试? 总结 A ...

  2. node-webkit学习(4)Native UI API 之window

    node-webkit学习(4)Native UI API 之window 文/玄魂 目录 node-webkit学习(4)Native UI API 之window 前言 4.1  window a ...

  3. Java JVM、JNI、Native Function Interface、Create New Process Native Function API Analysis

    目录 . JAVA JVM . Java JNI: Java Native Interface . Java Create New Process Native Function API Analys ...

  4. Linux Native Aio 异步AIO的研究

    Linux Native Aio 异步AIO的研究 http://rango.swoole.com/archives/282 首先声明一下epoll+nonblock从宏观角度可以叫做全异步,但从微观 ...

  5. node-webkit教程<>Native UI API 之Menu(菜单)

    node-webkit教程(6)Native UI API 之Menu(菜单)1 前言... 2 6.1  Menu 概述... 3 6.2  menu api6 6.2.1  new Menu([o ...

  6. API测试工具SoapUI & Postman对比分析

    本文由葡萄城技术团队于博客园原创并首发 转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 最近公司要引入API测试工具,经过调查和了解,最终决定在SoapUI ...

  7. NODE-WEBKIT教程(6)NATIVE UI API 之MENU(菜单)

    node-webkit教程(6)Native UI API 之Menu(菜单) 文/玄魂 目录 node-webkit教程(6)Native UI API 之Menu(菜单) 前言 6.1  Menu ...

  8. NODE-WEBKIT教程(5)NATIVE UI API 之FRAMELESS WINDOW

    node-webkit教程(5)Native UI API 之Frameless window 文/玄魂 原文链接:http://www.xuanhun521.com/Blog/2014/4/15/n ...

  9. 如何选择API测试工具

    没有最好,只有最合适. 如今,越来越多的公司正在向DevOps的方向左转,以实现持续集成和持续部署开发.这意味着我们的反馈需要比以往更快,以便确定我们的应用程序是否准备好交付.这就是API测试如此重要 ...

随机推荐

  1. 免费的.net云平台appharbor.com

    支持Mysql,MSSQL2008R2免费的都是20MB 提供codeplex,GitHub,BitBucket部署到appharbor.com 也可以使用Git来部署应用,但不支持FTP 可以一键安 ...

  2. [Grunt] Uglify

    Grunt Uglify to compress your javascript for production deployment. Install npm install grunt-contri ...

  3. Windows Server 2012怎样部署Domain Controller

    用过Windows Server2008 系统的运维师们,可能习惯于用dcpromo的方式部署Domain Controller,可是在WindowsServer2012操作系统已经把这样的部署方式取 ...

  4. git stash笔记

    日常工作中经常会需要放下手头上的工作,转而去修改之前的某一个bug,此时就需要将现有的改动添加到staging area git add . 然后将这些改动暂时放入一个stack中: git stas ...

  5. QtGui.QPen

    The QtGui.QPen is an elementary graphics object. It is used to draw lines, curves and outlines of re ...

  6. Map 和 WeakMap 数据结构

    Map 和 WeakMap 是ES6 新增的数据结构 一.Map 它们本质与对象一样,都是键值对的集合,但是他们与 Object 对象主要的不同是,键可以是各种类型的数值,而Object 对象的键 只 ...

  7. <续>调度算法补充

    cpmpute->executors: 1.从storm配置获取<compoent-id,parallelism>集合 2.storm-task-info 获得<task-id ...

  8. UVA1492 - Adding New Machine(扫描线)

    UVA1492 - Adding New Machine(扫描线) option=com_onlinejudge&Itemid=8&page=show_problem&cate ...

  9. 【CentOS6.5】MySQL安装和配置

    1./etc/my.cnf 这是mysql的主配置文件 2.数据存放位置 3.错误存放位置

  10. 【小程序】微信小程序之地图功能

    转载请注明出处:http://blog.csdn.net/crazy1235/article/details/55004841 基本使用 地图组件使用起来也很简单. .wxml <map id= ...