一个同步队列例子

这个用的也比较少, 做一个参考, 原文见[url=http://examples.javacodegeeks.com/core-java/util/concurrent/synchronous-queue-example-to-execute-commands]这里[/url]

private BlockingQueue workQueue = new LinkedBlockingQueue();
private Map commandQueueMap = new ConcurrentHashMap();

public SynchronousQueue addCommand(Command command) {
SynchronousQueue queue = new SynchronousQueue();
commandQueueMap.put(command, queue);
workQueue.offer(command);
return queue;
}

public Object call() throws Exception {
try {
Command command = workQueue.take();
Result result = command.execute();
SynchronousQueue queue = commandQueueMap.get(command);
queue.offer(result);
return null;
} catch (InterruptedException e) {
throw new WorkException(e);
}
}


Command command;
SynchronousQueue queue = commandRunner.addCommand(command);
Result result = queue.poll(2, TimeUnit.MINUTES);
if (result == null) {
throw new CommandTooLongException(command);
} else {
return result;
}
Freertos是一个免费开源的实时操作系统(RTOS),主要用于嵌入式系统,特别是物联网设备。队列是其通信机制的一部分,用于线程间的同步和数据传递。下面是一个简单的创建、使用以及生产者消费者模式的例子: ```c #include "FreeRTOS.h" #include "task.h" #include "queue.h" // 定义一个队列,最大容量为10 #define QUEUE_SIZE 10 typedef struct { int data; } QueueItem; // 队列结构体 QueueHandle_t queue_handle = NULL; void vCreateQueue(void) { // 创建队列 queue_handle = xQueueCreate(QUEUE_SIZE, sizeof(QueueItem)); } // 生产者任务函数 void vProducerTask(void *pvParameters) { for (;;) { // 从生产者获取数据 QueueItem item = {rand() % 100}; // 示例数据 // 将数据放入队列 if (xQueueSend(queue_handle, &item, portMAX_DELAY) == pdTRUE) { printf("Produced value: %d\n", item.data); } else { vTaskDelay(pdMS_TO_TICKS(500)); // 如果队满,等待一段时间再试 } } } // 消费者任务函数 void vConsumerTask(void *pvParameters) { for (;;) { // 从队列接收数据 QueueItem *pItem = NULL; if (xQueueReceive(queue_handle, &pItem, portMAX_DELAY) == pdTRUE) { printf("Consumed value: %d\n", pItem->data); vQueueDelete(pItem); // 使用完后释放队列资源 } else { vTaskDelay(pdMS_TO_TICKS(500)); // 如果队空,等待一段时间再试 } } } int main() { vApplicationInitialise(); vCreateQueue(); // 初始化队列 // 创建并启动生产者任务 xTaskCreate(vProducerTask, "Producer", configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY + 1, NULL); // 创建并启动消费者任务 xTaskCreate(vConsumerTask, "Consumer", configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY + 1, NULL); vTaskStartScheduler(); // 这里永远不会到达,因为一旦调度器运行,程序就不再继续 return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值