99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

stm32多線程 單片機(jī)如何實(shí)現(xiàn)多線程

如意 ? 來(lái)源:百度百科、與非網(wǎng)、CSDN ? 作者:百度百科、與非網(wǎng) ? 2021-07-22 14:51 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

stm32多線程單片機(jī)如何實(shí)現(xiàn)多線程

STM 32系列是專門應(yīng)用在高性能、低成本、低功耗的嵌入式應(yīng)用設(shè)計(jì)的ARM Corte-M0,M0+,M3,M4和M7內(nèi)核,是主流的嵌入式單片機(jī)之一。

多線程通常是指從計(jì)算機(jī)軟件或硬件上實(shí)現(xiàn)多個(gè)線程并發(fā)執(zhí)行的技術(shù),多線程技術(shù)有利于提升計(jì)算機(jī)整體處理性能。

基于STM32單片機(jī)的多線程源代碼實(shí)例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 //定義線程的個(gè)數(shù)

//定義函數(shù)指針

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

//線程函數(shù)表

const pTaskEventHandlerFn tasksArr[] =

{

Hal_ProcessEvent,

App_ProcessEvent

};

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

//uint16 *tasksEvents;

uint16 tasksEvents[TASK_CNT] = { 0}; //每個(gè)線程有16位位域空間用于設(shè)置事件

static uint8 activeTaskID = 0xFF; //當(dāng)前任務(wù)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(); //系統(tǒng)時(shí)鐘初始化

delayInit( 72); //滴答定時(shí)器初始化

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]) //輪訓(xùn)獲知哪個(gè)線程有事件需要進(jìn)行處理

{

break;

}

}

while (++idx 《 tasksCnt);

if (idx 《 tasksCnt)

{

uint16 events;

events = tasksEvents[idx];

tasksEvents[idx] = 0; // 清除事件數(shù)組中的事件

activeTaskID = idx;

events = (tasksArr[idx])( idx, events ); //調(diào)用線程函數(shù)

activeTaskID = TASK_NO_TASK_RUNNING;

tasksEvents[idx] |= events; // 添加未處理的事件到本線程的事件組中

}

delayMs( 1000);

}

}

/**

* @brief 應(yīng)用層處理

* @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單片機(jī)的多線程源代碼實(shí)例2:

public class SimpleThread {

//私有的靜態(tài)成員內(nèi)部類,實(shí)現(xiàn)了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(“不能正常工作”);

}

}

}

//顯示消息,消息是當(dāng)前線程的名字

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線程之前延遲的毫秒數(shù)(默認(rèn)是一分鐘)

long delay =1000 * 60;

//如果有命令行參數(shù),那么在命令行參數(shù)中給出推遲的時(shí)間

if(args.length》0){

try {

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

} catch (NumberFormatException e) {

System.err.println(“參數(shù)必須是整數(shù)”);

System.exit(1);

}

}

displayThreadMessage(“啟動(dòng)線程ThreadMessage.。?!保?

long startTime = System.currentTimeMillis();

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

t.start();

displayThreadMessage(“等待線程ThreadMessage結(jié)速。。。”);

//循環(huán)直到ThreadMessage線程退出

while(t.isAlive()){

displayThreadMessage(“繼續(xù)等待線程ThreadMessage.。?!保?

//最多等待3秒鐘ThreadMessage線程結(jié)速

t.join(3000);

//如果線程t運(yùn)行的時(shí)間超過(guò)delay指定時(shí)間

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

displayThreadMessage(“線程ThreadMessage運(yùn)行時(shí)間太久了,不想等待!”);

t.interrupt();

t.join();

}

}

displayThreadMessage(“結(jié)束線程ThreadMessage?。。 保?

}

}

基于STM32單片機(jī)的多線程源代碼實(shí)例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 // 定義線程的個(gè)數(shù)

// 定義函數(shù)指針

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

// 線程函數(shù)表

const pTaskEventHandlerFn tasksArr[] =

{

Hal_ProcessEvent,

App_ProcessEvent

};

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

//uint16 *tasksEvents;

uint16 tasksEvents[TASK_CNT] = {0}; // 每個(gè)線程有 16 位位域空間用于設(shè)置事件

staTIc uint8 acTIveTaskID = 0xFF; // 當(dāng)前任務(wù) 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(); // 系統(tǒng)時(shí)鐘初始化

delayInit(72); // 滴答定時(shí)器初始化

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]) // 輪訓(xùn)獲知哪個(gè)線程有事件需要進(jìn)行處理

{

break;

}

}

while (++idx 《 tasksCnt);

if (idx 《 tasksCnt)

{

uint16 events;

events = tasksEvents[idx];

tasksEvents[idx] = 0; // 清除事件數(shù)組中的事件

acTIveTaskID = idx;

events = (tasksArr[idx])( idx, events ); // 調(diào)用線程函數(shù)

activeTaskID = TASK_NO_TASK_RUNNING;

tasksEvents[idx] |= events; // 添加未處理的事件到本線程的事件組中

}

delayMs(1000);

}

}

/**

* @brief 應(yīng)用層處理

* @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; // 清除事件

以上是關(guān)于STM32單片機(jī)的源代碼,希望對(duì)用戶有所幫助。

本文整合自百度百科、與非網(wǎng)、CSDN-辣條boy

責(zé)編AJX

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 單片機(jī)
    +關(guān)注

    關(guān)注

    6067

    文章

    44991

    瀏覽量

    650411
  • STM32
    +關(guān)注

    關(guān)注

    2293

    文章

    11032

    瀏覽量

    364866
  • 多線程
    +關(guān)注

    關(guān)注

    0

    文章

    279

    瀏覽量

    20440
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    多線程的安全注意事項(xiàng)

    多線程安全是指多個(gè)線程同時(shí)訪問(wèn)或修改共享資源時(shí),能夠保證程序的正確性和可靠性。 開(kāi)發(fā)者選擇TaskPool或Worker進(jìn)行多線程開(kāi)發(fā)時(shí),在TaskPool和Worker的工作線程中導(dǎo)
    發(fā)表于 06-20 07:49

    鴻蒙5開(kāi)發(fā)寶藏案例分享---跨線程性能優(yōu)化指南

    ;>Worker</span>做多線程開(kāi)發(fā)時(shí),總遇到對(duì)象跨線程卡頓的問(wèn)題,原來(lái)鴻蒙早就提供了解決方案。下面結(jié)合代碼和實(shí)戰(zhàn)案例,帶你徹底玩轉(zhuǎn)性能優(yōu)化! 一、痛點(diǎn):跨線程
    發(fā)表于 06-12 17:13

    工控一體機(jī)多線程任務(wù)調(diào)度優(yōu)化:聚徽分享破解工業(yè)復(fù)雜流程高效協(xié)同密碼

    在當(dāng)今工業(yè) 4.0 的浪潮下,工業(yè)生產(chǎn)正朝著高度自動(dòng)化、智能化的方向大步邁進(jìn)。生產(chǎn)流程日益復(fù)雜,眾多任務(wù)需要同時(shí)、高效地協(xié)同執(zhí)行,這對(duì)工業(yè)控制系統(tǒng)的核心 —— 工控一體機(jī)提出了前所未有的挑戰(zhàn)。多線程
    的頭像 發(fā)表于 05-28 14:06 ?168次閱讀

    一種實(shí)時(shí)多線程VSLAM框架vS-Graphs介紹

    針對(duì)現(xiàn)有VSLAM系統(tǒng)語(yǔ)義表達(dá)不足、地圖可解釋性差的問(wèn)題,本文提出vS-Graphs,一種實(shí)時(shí)多線程VSLAM框架。該方案顯著提升了重建地圖的語(yǔ)義豐富度、可解釋性及定位精度。實(shí)驗(yàn)表明
    的頭像 發(fā)表于 04-19 14:07 ?394次閱讀
    一種實(shí)時(shí)<b class='flag-5'>多線程</b>VSLAM框架vS-Graphs介紹

    進(jìn)程、線程、協(xié)程傻傻分不清?一文帶你徹底扒光它們的\"底褲\"!

    外賣員(線程C):負(fù)責(zé)送外賣他們共用: 原料冰箱(共享內(nèi)存) 工作臺(tái)(??臻g)但不共享: 自己的工牌(線程ID) 心情日記(線程本地存儲(chǔ)) 代碼示例(Python多線程下載): im
    發(fā)表于 03-26 09:27

    請(qǐng)問(wèn)如何在Python中實(shí)現(xiàn)多線程與多進(jìn)程的協(xié)作?

    大家好!我最近在開(kāi)發(fā)一個(gè)Python項(xiàng)目時(shí),需要同時(shí)處理多個(gè)任務(wù),且每個(gè)任務(wù)需要不同的計(jì)算資源。我想通過(guò)多線程和多進(jìn)程的組合來(lái)實(shí)現(xiàn)并發(fā),但遇到了一些問(wèn)題。 具體來(lái)說(shuō),我有兩個(gè)任務(wù),一個(gè)是I/O密集型
    發(fā)表于 03-11 06:57

    請(qǐng)問(wèn)rt-thread studio如何進(jìn)行多線程編譯?

    ,使用的是5800h+32g內(nèi)存+sn550 ssd,開(kāi)啟16線程編譯時(shí)cpu的占用率也只能到30%,編譯完整個(gè)工程需要3分鐘 感覺(jué)多線程編譯設(shè)置沒(méi)有生效,有辦法提高編譯速度嗎
    發(fā)表于 02-19 08:30

    探索字節(jié)隊(duì)列的魔法:多類型支持、函數(shù)重載與線程安全

    的數(shù)據(jù)結(jié)構(gòu),它能夠高效地存儲(chǔ)和管理數(shù)據(jù)流。通過(guò)使用字節(jié)隊(duì)列,我們可以靈活地處理不同類型的數(shù)據(jù)、確保數(shù)據(jù)的完整性,并在多線程環(huán)境中安全地進(jìn)行操作。本文將深入探討字節(jié)
    的頭像 發(fā)表于 11-15 01:08 ?1238次閱讀
    探索字節(jié)隊(duì)列的魔法:多類型支持、函數(shù)重載與<b class='flag-5'>線程</b>安全

    socket 多線程編程實(shí)現(xiàn)方法

    在現(xiàn)代網(wǎng)絡(luò)編程中,多線程技術(shù)被廣泛應(yīng)用于提高服務(wù)器的并發(fā)處理能力。Socket編程是網(wǎng)絡(luò)通信的基礎(chǔ),而將多線程技術(shù)應(yīng)用于Socket編程,可以顯著提升服務(wù)器的性能。 多線程編程的基本概念 多線
    的頭像 發(fā)表于 11-12 14:16 ?1014次閱讀

    Python中多線程和多進(jìn)程的區(qū)別

    Python作為一種高級(jí)編程語(yǔ)言,提供了多種并發(fā)編程的方式,其中多線程與多進(jìn)程是最常見(jiàn)的兩種方式之一。在本文中,我們將探討Python中多線程與多進(jìn)程的概念、區(qū)別以及如何使用線程池與進(jìn)程池來(lái)提高并發(fā)執(zhí)行效率。
    的頭像 發(fā)表于 10-23 11:48 ?1020次閱讀
    Python中<b class='flag-5'>多線程</b>和多進(jìn)程的區(qū)別

    CPU線程和程序線程的區(qū)別

    CPU的線程與程序的線程在概念、作用、實(shí)現(xiàn)方式以及性能影響等方面存在顯著差異。以下是對(duì)兩者區(qū)別的詳細(xì)闡述,旨在深入探討這一技術(shù)話題。
    的頭像 發(fā)表于 09-02 11:18 ?2130次閱讀

    stm32單片機(jī)用什么軟件編程

    STM32單片機(jī)是一種廣泛應(yīng)用于嵌入式系統(tǒng)領(lǐng)域的微控制器,具有高性能、低功耗、豐富的外設(shè)接口等特點(diǎn)。要對(duì)STM32單片機(jī)進(jìn)行編程,需要選擇合適的軟件工具。 概述
    的頭像 發(fā)表于 09-02 10:16 ?3476次閱讀

    一文掌握Python多線程

    使用線程可以把占據(jù)長(zhǎng)時(shí)間的程序中的任務(wù)放到后臺(tái)去處理。
    的頭像 發(fā)表于 08-05 15:46 ?1258次閱讀

    LWIP多線程強(qiáng)烈建議開(kāi)啟LWIP_ASSERT_CORE_LOCKED宏,這個(gè)在RTT里面要怎么實(shí)現(xiàn)

    LWIP多線程強(qiáng)烈建議開(kāi)啟LWIP_ASSERT_CORE_LOCKED宏,這個(gè)在RTT里面要怎么實(shí)現(xiàn),之前參考網(wǎng)上代碼,這樣寫,壓力測(cè)試下有概率斷言失敗 extern sys_mutex_t
    發(fā)表于 07-25 06:27

    ESP32會(huì)不會(huì)有多線程問(wèn)題,需要加鎖嗎?

    ESP32會(huì)不會(huì)有多線程問(wèn)題,需要加鎖嗎
    發(fā)表于 07-19 08:05