⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 testqueue.c

📁 Apache官方在今天放出产品系列2.2的最新版本2.2.11的源码包 最流行的HTTP服务器软件之一
💻 C
字号:
/* Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements.  See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License.  You may obtain a copy of the License at * *     http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */#include "apu.h"#include "apr_queue.h"#include "apr_thread_pool.h"#include "apr_time.h"#include "abts.h"#include "testutil.h"#if APR_HAS_THREADS#define NUMBER_CONSUMERS    3#define CONSUMER_ACTIVITY   4#define NUMBER_PRODUCERS    4#define PRODUCER_ACTIVITY   5#define QUEUE_SIZE          100static apr_queue_t *queue;static void * APR_THREAD_FUNC consumer(apr_thread_t *thd, void *data){    long sleeprate;    abts_case *tc = data;    apr_status_t rv;    void *v;    sleeprate = 1000000/CONSUMER_ACTIVITY;    apr_sleep((rand() % 4) * 1000000); /* sleep random seconds */    while (1)    {        rv = apr_queue_pop(queue, &v);        if (rv == APR_EINTR)            continue;        if (rv == APR_EOF)            break;        ABTS_TRUE(tc, v == NULL);        ABTS_TRUE(tc, rv == APR_SUCCESS);        apr_sleep(sleeprate); /* sleep this long to acheive our rate */    }    return NULL;}static void * APR_THREAD_FUNC producer(apr_thread_t *thd, void *data){    long sleeprate;    abts_case *tc = data;    apr_status_t rv;    sleeprate = 1000000/PRODUCER_ACTIVITY;    apr_sleep((rand() % 4) * 1000000); /* sleep random seconds */    while (1)    {        rv = apr_queue_push(queue, NULL);        if (rv == APR_EINTR)            continue;        if (rv == APR_EOF)            break;        ABTS_TRUE(tc, rv == APR_SUCCESS);        apr_sleep(sleeprate); /* sleep this long to acheive our rate */    }    return NULL;}static void test_queue_producer_consumer(abts_case *tc, void *data){    unsigned int i;    apr_status_t rv;    apr_thread_pool_t *thrp;    /* XXX: non-portable */    srand((unsigned int)apr_time_now());    rv = apr_queue_create(&queue, QUEUE_SIZE, p);    ABTS_INT_EQUAL(tc, APR_SUCCESS, rv);    rv = apr_thread_pool_create(&thrp, 0, NUMBER_CONSUMERS + NUMBER_PRODUCERS, p);    ABTS_INT_EQUAL(tc, APR_SUCCESS, rv);    for (i = 0; i < NUMBER_CONSUMERS; i++) {        rv = apr_thread_pool_push(thrp, consumer, tc, 0, NULL);        ABTS_INT_EQUAL(tc, APR_SUCCESS, rv);    }    for (i = 0; i < NUMBER_PRODUCERS; i++) {        rv = apr_thread_pool_push(thrp, producer, tc, 0, NULL);        ABTS_INT_EQUAL(tc, APR_SUCCESS, rv);    }    apr_sleep(5000000); /* sleep 5 seconds */    rv = apr_queue_term(queue);    ABTS_INT_EQUAL(tc, APR_SUCCESS, rv);    rv = apr_thread_pool_destroy(thrp);    ABTS_INT_EQUAL(tc, APR_SUCCESS, rv);}#endif /* APR_HAS_THREADS */abts_suite *testqueue(abts_suite *suite){    suite = ADD_SUITE(suite);#if APR_HAS_THREADS    abts_run_test(suite, test_queue_producer_consumer, NULL);#endif /* APR_HAS_THREADS */    return suite;}

⌨️ 快捷键说明

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