技术标签: C语言 Message Handler队列 Handler C语言队列 队列
首先是头文件handler.h
#include <stdio.h>
#include <pthread.h>
struct list_head {
struct list_head *prev, *next;
};
#define list_entry(ptr, type, member) \
((type *)((uintptr_t)(ptr) - (uintptr_t)offsetof(type, member)))
#define list_first_entry(ptr, type, member) \
list_entry((ptr)->next, type, member)
#define list_for_each_entry(pos, head, member, type) \
for (pos = list_entry((head)->next, type, member); \
&pos->member != (head); \
pos = list_entry(pos->member.next, type, member))
#define list_for_each_entry_safe(pos, n, head, member, type) \
for (pos = list_entry((head)->next, type, member), \
n = list_entry(pos->member.next, type, member); \
&pos->member != (head); \
pos = n, n = list_entry(n->member.next, type, member))
#define list_empty(entry) ((entry)->next == (entry))
static inline void list_init(struct list_head *entry)
{
entry->prev = entry->next = entry;
}
static inline void list_add(struct list_head *entry, struct list_head *head)
{
entry->next = head->next;
entry->prev = head;
head->next->prev = entry;
head->next = entry;
}
static inline void list_add_tail(struct list_head *entry,
struct list_head *head)
{
entry->next = head;
entry->prev = head->prev;
head->prev->next = entry;
head->prev = entry;
}
static inline void list_del(struct list_head *entry)
{
entry->next->prev = entry->prev;
entry->prev->next = entry->next;
entry->next = entry->prev = NULL;
}
static inline void list_cut(struct list_head *list, struct list_head *head)
{
if (list_empty(head))
return;
list->next = head->next;
list->next->prev = list;
list->prev = head->prev;
list->prev->next = list;
list_init(head);
}
static inline void *usbi_reallocf(void *ptr, size_t size)
{
void *ret = realloc(ptr, size);
if (!ret)
free(ptr);
return ret;
}
#define container_of(ptr, type, member) ({ \
const typeof( ((type *)0)->member ) *mptr = (ptr); \
(type *)( (char *)mptr - offsetof(type,member) );})
enum handle_code {
SUCCESS,
NO_MEMORY = -1,
INIT_FAILED = -2,
};
struct message {
int what;
int arg1;
int arg2;
void *user_data;
struct list_head list;
};
然后是handler.c, obtain_message可以取缓存的message,测试代码也放在handler.c中,测试不完全,如有bug,欢迎指正,谢谢。
#include "handler.h"
struct message_control {
pthread_mutex_t lock;
pthread_cond_t cond;
struct list_head list;
int cache_list_number;
struct list_head cache_list;
};
static struct message_control *s_msg_ctl;
void wait_for_message(struct message **msg)
{
pthread_mutex_lock(&s_msg_ctl->lock);
struct message *tmp_msg;
if(list_empty(&s_msg_ctl->list)) {
pthread_mutex_unlock(&s_msg_ctl->lock);
pthread_cond_wait(&s_msg_ctl->cond, NULL);
pthread_mutex_lock(&s_msg_ctl->lock);
}
tmp_msg = *msg = list_first_entry(&s_msg_ctl->list, struct message, list);
list_del(&tmp_msg->list);
list_add_tail(&tmp_msg->list, &s_msg_ctl->cache_list);
s_msg_ctl->cache_list_number++;
pthread_mutex_unlock(&s_msg_ctl->lock);
}
void free_message(struct message *msg) {
pthread_mutex_lock(&s_msg_ctl->lock);
struct message *tmp_msg;
list_for_each_entry(tmp_msg, &s_msg_ctl->cache_list, list, struct message) {
if(msg == tmp_msg) {
break;
}
}
if(tmp_msg)
{
list_del(&tmp_msg->list);
s_msg_ctl->cache_list_number--;
free(tmp_msg);
tmp_msg = NULL;
}
pthread_mutex_unlock(&s_msg_ctl->lock);
}
struct message *obtain_message() {
pthread_mutex_lock(&s_msg_ctl->lock);
struct message *msg = NULL;
if(list_empty(&s_msg_ctl->cache_list)) {
msg = calloc(1, sizeof(struct message));
} else {
msg = list_first_entry(&s_msg_ctl->cache_list, struct message, list);
}
pthread_mutex_unlock(&s_msg_ctl->lock);
return msg;
}
void send_message(struct message *msg)
{
pthread_mutex_lock(&s_msg_ctl->lock);
list_add_tail(&msg->list, &s_msg_ctl->list);
pthread_cond_broadcast(&s_msg_ctl->cond);
pthread_mutex_unlock(&s_msg_ctl->lock);
}
int init_handler()
{
s_msg_ctl = calloc(1, sizeof(struct message_control));
if(!s_msg_ctl)
{
return NO_MEMORY;
}
list_init(&s_msg_ctl->list);
list_init(&s_msg_ctl->cache_list);
pthread_mutex_init(&s_msg_ctl->lock, NULL);
pthread_cond_init(&s_msg_ctl->cond, NULL);
s_msg_ctl->cache_list_number = 0;
return 0;
}
//=======================================================================================================================
void *thread_handler(void *param)
{
struct message *msg;
while(1) {
wait_for_message(&msg);
printf("receive a message what:%d, arg1:%d, arg2:%d, %s\n", msg->what, msg->arg1, msg->arg2, (char *)msg->user_data);
}
return NULL;
}
int main()
{
init_handler();
sleep(1);
pthread_t handler_tid;
pthread_create(&handler_tid, NULL, thread_handler, NULL);
while(1) {
printf("sleep 1\n");
sleep(1);
printf("sleep 2\n");
struct message *msg = obtain_message();
printf("obtain_message:%p\n", msg);
msg->what = 1;
msg->arg1 = 1;
msg->arg2 = 1;
msg->user_data = "hello handler message";
send_message(msg);
}
while(1){
sleep(22);
}
return 0;
}
文章浏览阅读556次,点赞2次,收藏3次。由于工作上的需要,今天捣鼓了半天高德地图。如果定制化开发需求不太高的话,可以用vue-amap,这个我就不多说了,详细就看官网 https://elemefe.github.io/vue-amap/#/zh-cn/introduction/install然而我们公司需要英文版的高德,我看vue-amap中好像没有这方面的配置,而且还有一些其他的定制化开发需求,然后就只用原生的高德。其实原生的引入也不复杂,但是有几个坑要填一下。1. index.html注意,引入的高德js一定要放在头部而_前端引入原生地图
文章浏览阅读104次。本文介绍ViewGroup重写,我们所熟知的LinearLayout,RelativeLayout,FrameLayout等等,所有的容器类都是ViewGroup的子类,ViewGroup又继承View。我们在熟练应用这些现成的系统布局的时候可能有时候就不能满足我们自己的需求了,这是我们就要自己重写一个容器来实现效果。ViewGroup重写可以达到各种效果,下面写一个简单的重写一个Vi..._viewgroup 重写
文章浏览阅读1.8w次,点赞279次,收藏1.5k次。本文章主要记录本人在学习stm32过程中的笔记,也插入了不少的例程代码,方便到时候CV。绝大多数内容为本人手写,小部分来自stm32官方的中文参考手册以及网上其他文章;代码部分大多来自江科大和正点原子的例程,注释是我自己添加;配图来自江科大/正点原子/中文参考手册。笔记内容都是平时自己一点点添加,不知不觉都已经这么长了。其实每一个标题其实都可以发一篇,但是这样搞太琐碎了,所以还是就这样吧。_stm32笔记
文章浏览阅读1.8k次。Android o CTS 测试之Media相关测试failed 小结(一)CTSCTS 即兼容性测试套件,CTS 在桌面设备上运行,并直接在连接的设备或模拟器上执行测试用例。CTS 是一套单元测试,旨在集成到工程师构建设备的日常工作流程(例如通过连续构建系统)中。其目的是尽早发现不兼容性,并确保软件在整个开发过程中保持兼容性。CTS 是一个自动化测试工具,其中包括两个主要软件组件:CTS tra..._mediacodec框架 cts
文章浏览阅读4.5k次。官网:https://harvesthq.github.io/chosen/实例化$(".chosen-select").chosen({disable_search_threshold: 10});赋值var optValue = $(".chosen-select").val();回显1.设置回显的值$(".chosen-select").val(“opt1”);2.触发cho..._chosen.js
文章浏览阅读1.9k次。撸码不易,网上找不到,索性自己写,且撸且珍惜!void bitsWrite(uint8_t* buff, int pos, int size, uint32_t value){ uint32_t index[] = { 0x80000000, 0x40000000, 0x20000000, 0x10000000, 0x8000000, 0x4000000, 0x2000000, 0x1000000, 0x800000, 0x400000, 0_unit8_t 集合 赋值 c++
文章浏览阅读748次。javaweb知识点_javaweb框架图
文章浏览阅读1.1w次,点赞3次,收藏16次。adb是没有自动升级的命令的,如果想要更新adb的版本,我们可以在网上找到自己想要的版本进行更新给大家提供几个版本https://pan.baidu.com/s/1yd0dsmWn5CK08MlyuubR7g&shfl=shareset 提取码: 94z81、下载解压后我们可以找到下面几个文件,并复制2、找到adb安装的文件夹下的platform-tools文件夹,我这里是..._adb iptabls怎么升级
文章浏览阅读3.8k次。很多用户可能都知道怎么在Windows系统上删除微信的聊天记录,那么苹果电脑上的微信软件怎么删除所有的聊天记录呢?下面小编就专门来给大家讲下微信mac版删除所有的聊天记录的图文教程。点击后会弹出提示窗口,点击这里的确认按钮就可以将其清理掉了。在这里选择要清理的数据,然后点击下方右边的清理按钮就行了。在mac上打开微信后,点击左下角的横线图标。然后再点击这里的管理微信聊天数据按钮。打开了设置窗口,点击上方的“通用”。在这里点击下方的前往清理按钮。点击弹出菜单里的“设置”。_mac微信怎么删除聊天列表
文章浏览阅读7.7k次。数据类型转换时报错:Request processing failed;nested exception is java.lang.NumberFormatException:For input String “20151512345”报错原因:数字格式异常,接着后面有 For input string: “201515612343” 提示,这就告诉我们你当前想把 “201515612343” 转换成数字类型时出错了。解决方案:使用2015151612343这个数字太大了,所以直接使用string_request processing failed; nested exception is java.lang.numberformatexcepti
文章浏览阅读387次。版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本文链接:https://blog.csdn.net/a844651990/article/details/78376767Qt qml 自定义消息提示框QtQuick有提供比较传统的信息提示框MessageDialog,但是实际开发过程并不太能满足我们的需求。下面是根据controls2模块中..._qml 自定义 messagedialog
文章浏览阅读599次。# Redis configuration file example.## Note that in order to read the configuration file, Redis must be# started with the file path as first argument:## ./redis-server /path/to/redis.conf # Note on units: when memory size is needed, it is pos._默认出厂的原始redis.conf文件全部内容