0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

stm32多线程 单片机如何实现多线程

如意 来源:百度百科、与非网、CSDN 作者:百度百科、与非网 2021-07-22 14:51 次阅读

stm32多线程单片机如何实现多线程

STM 32系列是专门应用在高性能、低成本、低功耗的嵌入式应用设计的ARM Corte-M0,M0+,M3,M4和M7内核,是主流的嵌入式单片机之一。

多线程通常是指从计算机软件或硬件上实现多个线程并发执行的技术,多线程技术有利于提升计算机整体处理性能。

基于STM32单片机的多线程源代码实例1:

#include “Hal_Led/Hal_Led.h”

#include “Hal_delay/delay.h”

#include “Hal_Key/Hal_Key.h”

#include “ringbuffer.h”

#define APP_LED2_BLINK_EVENT 0x0001

#define HAL_LED1_BLINK_EVENT 0x0001

#define TASK_NO_TASK_RUNNING 0xFF

unsigned short Hal_ProcessEvent( unsigned char task_id, unsigned short events );

unsigned short App_ProcessEvent( unsigned char task_id, unsigned short events );

typedef unsigned short uint16;

typedef unsigned char uint8;

#define TASK_CNT 2 //定义线程的个数

//定义函数指针

typedef unsigned short (*pTaskEventHandlerFn)( unsigned char task_id, unsigned short events );

//线程函数表

const pTaskEventHandlerFn tasksArr[] =

{

Hal_ProcessEvent,

App_ProcessEvent

};

const unsigned char tasksCnt = sizeof( tasksArr ) / sizeof( tasksArr[ 0] );

//uint16 *tasksEvents;

uint16 tasksEvents[TASK_CNT] = { 0}; //每个线程有16位位域空间用于设置事件

static uint8 activeTaskID = 0xFF; //当前任务ID,指示作用

#define SUCCESS 0x00

#define FAILURE 0x01

#define INVALID_TASK 0x02

uint8 osal_set_event( uint8 task_id, uint16 event_flag )

{

if ( task_id 《 tasksCnt )

{

tasksEvents[task_id] |= event_flag; // Stuff the event bit(s)

return ( SUCCESS );

}

else

{

return ( INVALID_TASK );

}

}

/**

* @brief 程序入口

* @param none

* @return none

*/

int main( void)

{

unsigned short taskID = 0;

uint8 idx = 0;

SystemInit(); //系统时钟初始化

delayInit( 72); //滴答定时器初始化

Led_Init(); //LED初始化

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);

osal_set_event( 0, HAL_LED1_BLINK_EVENT);

osal_set_event( 1, APP_LED2_BLINK_EVENT);

while( 1)

{

do

{

if(tasksEvents[idx]) //轮训获知哪个线程有事件需要进行处理

{

break;

}

}

while (++idx 《 tasksCnt);

if (idx 《 tasksCnt)

{

uint16 events;

events = tasksEvents[idx];

tasksEvents[idx] = 0; // 清除事件数组中的事件

activeTaskID = idx;

events = (tasksArr[idx])( idx, events ); //调用线程函数

activeTaskID = TASK_NO_TASK_RUNNING;

tasksEvents[idx] |= events; // 添加未处理的事件到本线程的事件组中

}

delayMs( 1000);

}

}

/**

* @brief 应用层处理

* @param none

* @r

*/

unsigned short Hal_ProcessEvent( unsigned char task_id, unsigned short events )

{

if ( events & HAL_LED1_BLINK_EVENT )

{

Led_Reverse( 1);

return events ^ HAL_LED1_BLINK_EVENT; //清除事件

}

}

/**

* @brief 硬件控制线程

* @param none

* @r

*/

unsigned short App_ProcessEvent( unsigned char task_id, unsigned short events )

{

if ( events & APP_LED2_BLINK_EVENT )

{

Led_Reverse( 2);

return events ^ APP_LED2_BLINK_EVENT; //清除事件

}

基于STM32单片机的多线程源代码实例2:

public class SimpleThread {

//私有的静态成员内部类,实现了Runnable接口

private static class ThreadMessage implements Runnable{

public void run(){

String[] info = {“消息1”,“消息2”, “消息3”, “消息4”};

try {

for(int i=0;i《info.length;i++){

Thread.sleep(4000);

displayThreadMessage(info[i]);

}

} catch (InterruptedException e) {

displayThreadMessage(“不能正常工作”);

}

}

}

//显示消息,消息是当前线程的名字

static void displayThreadMessage(String message){

String threadName = Thread.currentThread().getName();

//格式化输出线程消息

System.out.format(“%s: %s%n”, threadName, message);

}

public static void main(String[] args) throws InterruptedException {

// 中断ThreadMessage线程之前延迟的毫秒数(默认是一分钟)

long delay =1000 * 60;

//如果有命令行参数,那么在命令行参数中给出推迟的时间

if(args.length》0){

try {

delay =Long.parseLong(args[0])*1000;

} catch (NumberFormatException e) {

System.err.println(“参数必须是整数”);

System.exit(1);

}

}

displayThreadMessage(“启动线程ThreadMessage.。。”);

long startTime = System.currentTimeMillis();

Thread t = new Thread(new ThreadMessage());

t.start();

displayThreadMessage(“等待线程ThreadMessage结速。。。”);

//循环直到ThreadMessage线程退出

while(t.isAlive()){

displayThreadMessage(“继续等待线程ThreadMessage.。。”);

//最多等待3秒钟ThreadMessage线程结速

t.join(3000);

//如果线程t运行的时间超过delay指定时间

if(((System.currentTimeMillis() - startTime) 》 delay) && t.isAlive()){

displayThreadMessage(“线程ThreadMessage运行时间太久了,不想等待!”);

t.interrupt();

t.join();

}

}

displayThreadMessage(“结束线程ThreadMessage!!!”);

}

}

基于STM32单片机的多线程源代码实例3:

#include “Hal_Led/Hal_Led.h”

#include “Hal_delay/delay.h”

#include “Hal_Key/Hal_Key.h”

#include “ringbuffer.h”

#define APP_LED2_BLINK_EVENT 0x0001

#define HAL_LED1_BLINK_EVENT 0x0001

#define TASK_NO_TASK_RUNNING 0xFF

unsigned short Hal_ProcessEvent( unsigned char task_id, unsigned short events );

unsigned short App_ProcessEvent( unsigned char task_id, unsigned short events );

typedef unsigned short uint16;

typedef unsigned char uint8;

#define TASK_CNT 2 // 定义线程的个数

// 定义函数指针

typedef unsigned short (*pTaskEventHandlerFn)( unsigned char task_id, unsigned short events );

// 线程函数表

const pTaskEventHandlerFn tasksArr[] =

{

Hal_ProcessEvent,

App_ProcessEvent

};

const unsigned char tasksCnt = sizeof( tasksArr ) / sizeof( tasksArr[0] );

//uint16 *tasksEvents;

uint16 tasksEvents[TASK_CNT] = {0}; // 每个线程有 16 位位域空间用于设置事件

staTIc uint8 acTIveTaskID = 0xFF; // 当前任务 ID,指示作用

#define SUCCESS 0x00

#define FAILURE 0x01

#define INVALID_TASK 0x02

uint8 osal_set_event( uint8 task_id, uint16 event_flag )

{

if ( task_id 《 tasksCnt )

{

tasksEvents[task_id] |= event_flag; // Stuff the event bit(s)

return ( SUCCESS );

}

else

{

return ( INVALID_TASK );

}

}

/**

* @brief 程序入口

* @param none

* @return none

*/

int main(void)

{

unsigned short taskID = 0;

uint8 idx = 0;

SystemInit(); // 系统时钟初始化

delayInit(72); // 滴答定时器初始化

Led_Init(); //LED 初始化

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);

osal_set_event(0, HAL_LED1_BLINK_EVENT);

osal_set_event(1, APP_LED2_BLINK_EVENT);

while(1)

{

do

{

if(tasksEvents[idx]) // 轮训获知哪个线程有事件需要进行处理

{

break;

}

}

while (++idx 《 tasksCnt);

if (idx 《 tasksCnt)

{

uint16 events;

events = tasksEvents[idx];

tasksEvents[idx] = 0; // 清除事件数组中的事件

acTIveTaskID = idx;

events = (tasksArr[idx])( idx, events ); // 调用线程函数

activeTaskID = TASK_NO_TASK_RUNNING;

tasksEvents[idx] |= events; // 添加未处理的事件到本线程的事件组中

}

delayMs(1000);

}

}

/**

* @brief 应用层处理

* @param none

* @r

*/

unsigned short Hal_ProcessEvent( unsigned char task_id, unsigned short events )

{

if ( events & HAL_LED1_BLINK_EVENT )

{

Led_Reverse(1);

return events ^ HAL_LED1_BLINK_EVENT; // 清除事件

}

}

/**

* @brief 硬件控制线程

* @param none

* @r

*/

unsigned short App_ProcessEvent( unsigned char task_id, unsigned short events )

{

if ( events & APP_LED2_BLINK_EVENT )

{

Led_Reverse(2);

return events ^ APP_LED2_BLINK_EVENT; // 清除事件

以上是关于STM32单片机的源代码,希望对用户有所帮助。

本文整合自百度百科、与非网、CSDN-辣条boy

责编AJX

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    6020

    文章

    44353

    浏览量

    628206
  • STM32
    +关注

    关注

    2257

    文章

    10822

    浏览量

    352410
  • 多线程
    +关注

    关注

    0

    文章

    275

    浏览量

    19848
收藏 人收藏

    评论

    相关推荐

    多线程设计模式到对 CompletableFuture 的应用

    最近在开发 延保服务 频道页时,为了提高查询效率,使用到了多线程技术。为了对多线程方案设计有更加充分的了解,在业余时间读完了《图解 Java 多线程设计模式》这本书,觉得收获良多。本篇文章将介绍其中
    的头像 发表于 06-26 14:18 171次阅读
    从<b class='flag-5'>多线程</b>设计模式到对 CompletableFuture 的应用

    java实现多线程的几种方式

    Java实现多线程的几种方式 多线程是指程序中包含了两个或以上的线程,每个线程都可以并行执行不同的任务或操作。Java中的
    的头像 发表于 03-14 16:55 427次阅读

    AT socket可以多线程调用吗?

    请问AT socket 可以多线程调用吗? 有互锁机制吗,还是要自己做互锁。
    发表于 03-01 08:22

    redis多线程还能保证线程安全吗

    Redis是一种使用C语言编写的高性能键值存储系统,它是单线程的,因为使用了多路复用的方式来处理并发请求。这样的实现方式带来了很好的性能,但同时也引发了一些线程安全方面的问题。 在Redis中,由于
    的头像 发表于 12-05 10:28 1329次阅读

    mfc多线程编程实例

    (图形用户界面)应用程序的开发。在这篇文章中,我们将重点介绍MFC中的多线程编程。 多线程编程在软件开发中非常重要,它可以实现程序的并发执行,提高程序的效率和响应速度。MFC提供了丰富的多线程
    的头像 发表于 12-01 14:29 1131次阅读

    多线程如何保证数据的同步

    多线程编程是一种并发编程的方法,意味着程序中同时运行多个线程,每个线程可独立执行不同的任务,共享同一份数据。由于多线程并发执行的特点,会引发数据同步的问题,即保证多个
    的头像 发表于 11-17 14:22 869次阅读

    多线程并发查询oracle数据库

    数据库的原理、使用场景、实现方法以及可能遇到的问题和解决方案。 一、多线程并发查询的原理 在传统的单线程查询方式中,当一个查询请求发起时,数据库会按照顺序执行查询语句并返回结果。如果查询语句比较复杂或者数据量比较大,查询的时
    的头像 发表于 11-17 14:22 3075次阅读

    多线程同步的几种方法

    多线程同步是指在多个线程并发执行的情况下,为了保证线程执行的正确性和一致性,需要采用特定的方法来协调线程之间的执行顺序和共享资源的访问。下面将介绍几种常见的
    的头像 发表于 11-17 14:16 949次阅读

    Linux系统上多线程和多进程的运行效率

    关于多进程和多线程,教科书上最经典的一句话是“进程是资源分配的最小单位,线程是CPU调度的最小单位”,这句话应付考试基本上够了,但如果在工作中遇到类似的选择问题,那就没有这么简单了,选的不好,会让你
    的头像 发表于 11-10 10:54 1046次阅读
    Linux系统上<b class='flag-5'>多线程</b>和多进程的运行效率

    基于DSP/BIOS多线程的小型组合导航系统设计

    电子发烧友网站提供《基于DSP/BIOS多线程的小型组合导航系统设计.pdf》资料免费下载
    发表于 11-08 10:07 0次下载
    基于DSP/BIOS<b class='flag-5'>多线程</b>的小型组合导航系统设计

    关于Python多进程和多线程详解

    进程(process)和线程(thread)是操作系统的基本概念,但是它们比较抽象,不容易掌握。关于多进程和多线程,教科书上最经典的一句话是“进程是资源分配的最小单位,线程是CPU调度的最小单位”。
    的头像 发表于 11-06 14:46 684次阅读
    关于Python多进程和<b class='flag-5'>多线程</b>详解

    多线程idm下载软件

    多线程idm下载软件
    发表于 10-23 09:23 0次下载

    请问单片机怎么实现真正的多线程?

    单片机怎么实现真正的多线程?​
    发表于 10-18 06:45

    MDK可以支持多线程编译吗?

    怎么才能打开多线程编译
    发表于 10-11 07:23

    Java多线程的用法

    能力。 什么是进程 是指正在运行的程序的实例。 每个进程都拥有自己的内存空间、代码、数据和文件等资源,可以独立运行、调度和管理。在操作系统中,进程是系统资源分配的最小单位,是实现多任务的基础。 Java多线程 Java多线程是指
    的头像 发表于 09-30 17:07 837次阅读