queue.h

来自「Sun公司Dream项目」· C头文件 代码 · 共 107 行

H
107
字号
/*
 * The contents of this file are subject to the terms
 * of the Common Development and Distribution License
 * (the "License").  You may not use this file except
 * in compliance with the License.
 *
 * You can obtain a copy of the license at
 * http://www.opensource.org/licenses/cddl1.php
 * See the License for the specific language governing
 * permissions and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL
 * HEADER in each file and include the License file at
 * http://www.opensource.org/licenses/cddl1.php.  If 
 * applicable, add the following below this CDDL HEADER, 
 * with the fields enclosed by brackets "[]" replaced 
 * with your own identifying information: 
 * Portions Copyright [yyyy]
 * [name of copyright owner]
 */ 

/*
 * $(@)Queue.h $Revision: 1.1.1.1 $ $Date: 2006/04/17 22:47:30 $
 * 
 * Copyright 2006 Sun Microsystems, Inc. All Rights Reserved.
 */
/*
 * Copyright (c) 1997 by Sun Microsystems, Inc.
 */

/*
 * OBJECT Queue -- A queue is a MT-safe fifo.
 */
#ifndef	_COBJS_QUEUE_H
#define	_COBJS_QUEUE_H

#pragma ident "@(#)Queue.h 1.2	99/10/27 SMI"

#include <time.h>

#include "cobjs/Types.h"
#include "cobjs/Foreign.h"

_FOREIGN_START

/*
 * OBJECT Queue Instance Type
 */
typedef struct _Queue *Queue;

/*
 * OBJECT Queue Class Interface
 */

/*
 * Create a queue that will hold up to maxLen items.  Attempts to enqueue
 * more than maxLen items will block until items are dequeued.
 */
extern Queue        queueNew(int maxLen);

/*
 * OBJECT Queue Instance Interface
 */

/*
 * Enqueues item on queue.  If queue is full, will block until room available
 * in queue or until the timeoutDate occurs.  timeoutDatep == NULL implies
 * block until successful.
 * 
 * Attempting to enqueue NULL is an error.
 * 
 * Returns TRUE if enqueue successful, FALSE if timeout or queue is shutdown.
 */
extern Boolean
queueEnqueue(Queue queue, void *item,
	     timestruc_t *timeoutDatep);


/*
 * Dequeues item from queue, blocks if no items are present until
 * timeoutDate.  timeoutDatep == NULL implies block until item available or
 * queue shutdown is done.
 * 
 * Returns NULL if timeout or queue shutdown and empty.
 */
extern void        *queueDequeue(Queue queue, timestruc_t *timeoutDatep);

/*
 * Shutdown queue.  After shutdown all enqueues are rejected and
 * dequeues return NULL and do not block when queue is empty.
 */
extern void         queueShutdown(Queue queue);

/*
 * Returns TRUE if queue is not shutdown.
 */
extern Boolean      queueIsActive(Queue queue);

/*
 * Frees Queue object.  Error if queue is not empty.
 */
extern void         queueFree(Queue queue);

_FOREIGN_END

#endif					   /* _COBJS_QUEUE_H */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?