FressRTOS_day4:2024/4/4

1.总结二进制信号量和计数型信号量的区别,以及他们的使用场景。

二进制信号量的数值只有0和1。(用于共享资源的访问);而计数型信号量的值一般是大于或者等于2(用于生产者和消费者模型)


2.使用计数型信号量完成生产者和消费者模型实验。

代码:

void StartDefaultTask(void *argument)
{
  /* USER CODE BEGIN StartDefaultTask */
  /* Infinite loop */
	for(;;)
	{
		osSemaphoreAcquire(myCountingSem01Handle,osWaitForever);//获取生产者信号量
		printf("我生产了一辆特斯拉\r\n");
		
		osDelay(500);
	}
  /* USER CODE END StartDefaultTask */
}

/* USER CODE BEGIN Header_StartTask02 */
/**
* @brief Function implementing the myTask02 thread.
* @param argument: Not used
* @retval None
*/
/* USER CODE END Header_StartTask02 */
void StartTask02(void *argument)
{
  /* USER CODE BEGIN StartTask02 */
  /* Infinite loop */

  for(;;)
  {
		osSemaphoreRelease(myCountingSem01Handle);//释放生产者任务信号量
		printf("我买了一辆特斯拉\r\n");
    osDelay(500);
  }
  /* USER CODE END StartTask02 */
}

效果图:


3.总结FreeRTOS中同步和互斥的五种方法的使用方法

1.队列:先创建,创建队列有两种方式分别是动态创建和静态创建,动态创建使用xQueueCreate函数进行创建,静态创建使用xQueueCreateStatic函数进行创建。
队列创建成功后,可以开始往队列中写入和读取数据
写函数:
队列写操作也分为两种:分别是在中断中使用的一个函数:xQueueSendToBackFromISR,另一个是在任务中使用的:xQueueSendToBack。

读函数:
读函数也分为两种一种是在中断中进行队列的读取(xQueueReceiveFromISR),一种是在任务中进行队列的读取。(xQueueReceive)

2.信号量:在FreeRTOS中有两种信号量:二进制信号量、计数型信号量。

使用 osSemaphoreNew 函数创建信号量,使用 osSemaphoreAcquire 函数获取信号量,获取信号量后就可以访问共享资源,访问结束后,使用 osSemaphoreRelease 函数释放信号量,以便于其他任务访问共享资源。

3.互斥量:

创建互斥量:osMutexNew

获取互斥量函数:osMutexAcquire

释放互斥量函数:osMutexRelease

4.事件组:

在FreeRTOS中,事件组允许任务等待多个事件的状态,并且可以在任何事件被设置时唤醒等待的任务。

创建事件组函数:osEventFlagsNew

设置事件组函数:osEventFlagsSet

等待事件组函数:osEventFlagsWait

5.任务通知:

任务通知函数:osThreadFlagsSet

等待任务通知函数:osThreadFlagsWait


4.总结任务通知和其他任务通信机制的区别

1.队列、信号量、互斥量、事件组在使用之前都需要先创建,才能使用。任务通知无需创建即可使用。
2.队列、信号量、互斥量、事件组  是多对多通信。任务通知是多对一通信。(只需要知道要通知的任务ID即可)
3.队列、信号量、互斥量、事件组需要被创建,所以消耗的资源也是比较多。任务通知不需要被创建消耗的资源少。

思维导图

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
set user_write_ugi:afs://kunpeng.afs.baidu.com:9902=lbs-huiyan,lbs-huiyan; insert overwrite directory 'afs://kunpeng.afs.baidu.com:9902/user/lbs-huiyan/warehouse/huiyan.db/map_huiyan_mall_userpic/event_type=monthly/event_day={FORWARD_MONTH_END}' using CSV options('compression'='GZIP', sep='\t', escapeQuotes=false) SELECT source.mall_id AS mall_id, COUNT(1) AS total FROM (SELECT cuid, mall_id, mall_name, date_type FROM huiyan_ns.huiyan.map_huiyan_mall_basic_source WHERE event_day = '{FORWARD_MONTH_END}') source JOIN (SELECT cuid, * FROM huiyan_ns.huiyan.map_huiyan_parse_userpic WHERE event_day >= '{FORWARD_7_DAY}' AND event_day <= '{FORWARD_MONTH_END}') userpic ON userpic.cuid = source.cuid GROUP BY source.mall_id, source.mall_name, source.date_type; alter table huiyan_ns.huiyan.map_huiyan_mall_userpic_raw add partition(event_day='{FORWARD_MONTH_END}') location 'afs://kunpeng.afs.baidu.com:9902/user/lbs-huiyan/warehouse/huiyan.db/map_huiyan_mall_flow_userpic_raw/event_day={FORWARD_MONTH_END}'; set user_write_ugi:afs://kunpeng.afs.baidu.com:9902=lbs-huiyan,lbs-huiyan; insert overwrite directory 'afs://kunpeng.afs.baidu.com:9902/user/lbs-huiyan/warehouse/huiyan.db/map_huiyan_mall_userpic/event_type=monthly/event_day={FORWARD_MONTH_END}' using CSV options('compression'='GZIP', sep='\t', escapeQuotes=false) SELECT TRANSFORM(mall_id, ) USING 'python3 mall_userpic_streaming.py' AS(mall_id, ) FROM huiyan_ns.huiyan.map_huiyan_mall_userpic_raw WHERE event_day = '{FORWARD_MONTH_END}' ; alter table huiyan_ns.huiyan.map_huiyan_mall_userpic add partition(event_type='monthly', event_day='{FORWARD_MONTH_END}') location 'afs://kunpeng.afs.baidu.com:9902/user/lbs-huiyan/warehouse/huiyan.db/map_huiyan_mall_userpic/event_type=monthly/event_day=${FORWARD_MONTH_END}'; 将这两段代码合并为一段
07-22

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值