zoukankan      html  css  js  c++  java
  • 头文件中结构体互相引用的问题

    先上代码看下错误的例子:

    typedef struct _thread{
        int       id;                        /* friendly id               */
        pthread_t pthread;                   /* pointer to actual thread  */
        thpool_handle_t thpool_p;            /* access to thpool          */
    } thread_t;
    
    
    /* Threadpool
     * threadpool has many threads, and he should to access each threads, threads pointer array to save all threads pointer */
    typedef struct _thpool{
        thread_t**   threads;                  /* pointer to threads        */
        volatile int num_threads_alive;      /* threads currently alive   */
        volatile int num_threads_working;    /* threads currently working */
        pthread_mutex_t  thcount_lock;       /* used for thread count etc */
        jobqueue*  jobqueue_p;               /* pointer to the job queue  */
    } thpool_t, *thpool_handle_t;

    编译提示:
    ./include/thread_pool.h:31:5: error: unknown type name ‘thpool_handle_t’

    修改如下解决:

    struct _thread;
    struct _thpool;
    typedef struct _thread thread_t;
    typedef struct _thpool thpool_t, *thpool_handle_t;
    
    typedef struct _thread{
        int       id;                        /* friendly id               */
        pthread_t pthread;                   /* pointer to actual thread  */
        thpool_handle_t thpool_p;            /* access to thpool          */
    } thread_t;
    
    
    /* Threadpool
     * threadpool has many threads, and he should to access each threads, threads pointer array to save all threads pointer */
    typedef struct _thpool{
        thread_t**   threads;                  /* pointer to threads        */
        volatile int num_threads_alive;      /* threads currently alive   */
        volatile int num_threads_working;    /* threads currently working */
        pthread_mutex_t  thcount_lock;       /* used for thread count etc */
        jobqueue*  jobqueue_p;               /* pointer to the job queue  */
    } thpool_t, *thpool_handle_t;
  • 相关阅读:
    灌溉 最小生成树
    queue的应用uva540
    大数相加
    对于jquery实现原理的浅谈
    div+CSS实现页面的布局要点记录
    spring注解注入的学习
    jsp内置对象学习记录
    web应用的乱码解决
    新发现:排序算法时间复杂度只有O(3n),命名为"wgw"排序法
    java编写的Http协议的多线程下载器
  • 原文地址:https://www.cnblogs.com/biglucky/p/6349862.html
Copyright © 2011-2022 走看看