编译简单的 Apache Portable Runtime 1.5.2 程序

Compile simple Apache Portable Runtime 1.5.2 program

按照 here and here 中的步骤,我尝试使用 apr 1.5.2 和 apr-utils 1.5.4 编译一个简单的程序。这是程序的代码:

    #include <apr.h>
    #include <stdlib.h>

    int main(int argc, char *argv[]) {
        apr_pool_t *pool;
        apr_file_t *out;

        apr_initialize();
        atexit(apr_terminate());

        apr_pool_create(&pool, NULL);
        apr_file_open_stdout(&out, pool);

        apr_file_printf(out, "Hello World\n");

        apr_pool_destroy(pool);
        return EXIT_SUCCESS;
    }

现在,当我尝试使用以下 Makefile 编译它时,编译器 returns 错误。

生成文件:

    PREFIX?=/usr/local/apr
    CFLAGS=-g -Wall -I${PREFIX}/include/apr-1
    LDFLAGS=-L${PREFIX}/apr/lib -lapr-1 -pthread -laprutil-1
    CC=clang

    .PHONY: all clean
    all: hello

    clean:
            rm -f *.o

编译器输出:

 $ make
 clang -g -Wall -I/usr/local/apr/include/apr-1  -L/usr/local/apr/apr/lib -lapr-1 -pthread -laprutil-1  hello.c   -o hello
hello.c:5:5: error: use of undeclared identifier 'apr_pool_t'
    apr_pool_t *pool;
    ^
hello.c:5:17: error: use of undeclared identifier 'pool'
    apr_pool_t *pool;
                ^
hello.c:6:5: error: unknown type name 'apr_file_t'; did you mean 'apr_size_t'?
    apr_file_t *out;
    ^~~~~~~~~~
    apr_size_t
/usr/local/apr/include/apr-1/apr.h:356:26: note: 'apr_size_t' declared here
typedef  size_t          apr_size_t;
                         ^
hello.c:8:5: warning: implicit declaration of function 'apr_initialize' is
      invalid in C99 [-Wimplicit-function-declaration]
    apr_initialize();
    ^
hello.c:9:12: warning: implicit declaration of function 'apr_terminate' is
      invalid in C99 [-Wimplicit-function-declaration]
    atexit(apr_terminate());
           ^
hello.c:9:12: warning: incompatible integer to pointer conversion passing 'int'
      to parameter of type 'void (*)(void)' [-Wint-conversion]
    atexit(apr_terminate());
           ^~~~~~~~~~~~~~~
/usr/include/stdlib.h:519:27: note: passing argument to parameter '__func' here
extern int atexit (void (*__func) (void)) __THROW __nonnull ((1));
                          ^
hello.c:11:5: warning: implicit declaration of function 'apr_pool_create' is
      invalid in C99 [-Wimplicit-function-declaration]
    apr_pool_create(&pool, NULL);
    ^
hello.c:11:22: error: use of undeclared identifier 'pool'
    apr_pool_create(&pool, NULL);
                     ^
hello.c:12:5: warning: implicit declaration of function 'apr_file_open_stdout'
      is invalid in C99 [-Wimplicit-function-declaration]
    apr_file_open_stdout(&out, pool);
    ^
hello.c:12:32: error: use of undeclared identifier 'pool'
    apr_file_open_stdout(&out, pool);
                               ^
hello.c:13:5: warning: implicit declaration of function 'apr_file_printf' is
      invalid in C99 [-Wimplicit-function-declaration]
    apr_file_printf(out, "Hello World\n");
    ^
hello.c:14:5: warning: implicit declaration of function 'apr_pool_destroy' is
      invalid in C99 [-Wimplicit-function-declaration]
    apr_pool_destroy(pool);
    ^
hello.c:14:22: error: use of undeclared identifier 'pool'
    apr_pool_destroy(pool);
                     ^
7 warnings and 6 errors generated.
make: *** [hello] Error 1

注意:例子中,我拿了Makefile,还有一个link -I${PREFIX}/apr/include/apr-util-1,但是安装apr-utils时并没有创建这个文件夹

<apr.h> header 用于 platform definitions。它定义了 APR 可用的内容(有 WinAPI?有 OpenSSL?)和标准数据类型(apr_byte_tapr_uint32_t.. 等)。它由 ./configure.

在构建期间自动生成

您需要包括 apr_pools.hapr_file_io.h 分别用于内存池和文件 IO。

此外 atexit(3) 需要一个函数指针,而您传入​​了一个函数。相反,它应该说:

atexit(apr_terminate);

像这样的错误很容易自行调试。当编译器抱怨您正在使用的库中有未声明的标识符时,您几乎可以肯定是忘记了包含适当的 header.