Использование функций API GEOS в C lang возвращает ошибку сегментации - PullRequest
0 голосов
/ 09 апреля 2019

Я пытаюсь использовать некоторые функции libgeos (https://github.com/libgeos/geos) из моей C-программы. Ниже приведен мой код.

#include <stdio.h>
#include <geos_c.h>

int main() {

    GEOSContextHandle_t ctx  =  GEOS_init_r();

    GEOSGeometry *inputGeom = GEOSGeomFromWKT("MULTIPOLYGON (((30 20, 45 40, 10 40, 30 20)), ((15 5, 40 10, 10 20, 5 10, 15 5)))");

    printf("%s\n", GEOSGeomToWKT(inputGeom));

    GEOS_finish_r(ctx);

    return 0;
}

Но проблема в том, что я получаю ошибку сегментации, когдаЯ запускаю двоичный файл. Ниже приведена команда gcc, которую я использовал для компиляции программы.

gcc -g -Wall geos.c -o geos -lgeos_c

Пожалуйста, смотрите ниже вывод gdb.

(gdb) run
Starting program: /home/srimal/proj/src/geos/geos 
warning: the debug information found in "/lib64/ld-2.27.so" does not match "/lib64/ld-linux-x86-64.so.2" (CRC mismatch).


Program received signal SIGSEGV, Segmentation fault.
__strlen_avx2 () at ../sysdeps/x86_64/multiarch/strlen-avx2.S:62
62      ../sysdeps/x86_64/multiarch/strlen-avx2.S: No such file or directory.

Я был бы очень признателен, если кто-томожет помочь мне решить эту проблему.

1 Ответ

0 голосов
/ 09 апреля 2019

Решена проблема.Я должен был использовать функции initGEOS и finishGEOS.Ниже приведен правильный ответ с некоторыми улучшениями.

#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>

#include <geos_c.h>

void notice(const char *fmt, ...) {
    va_list ap;
    fprintf( stdout, "NOTICE: ");
    va_start (ap, fmt);
    vfprintf( stdout, fmt, ap);
    va_end(ap);
    fprintf( stdout, "\n" );
}

void log_and_exit(const char *fmt, ...) {
    va_list ap;
    fprintf( stdout, "ERROR: ");    
    va_start (ap, fmt);
    vfprintf( stdout, fmt, ap);
    va_end(ap);
    fprintf( stdout, "\n" );
    exit(1);
}

int main() {

    initGEOS(notice, log_and_exit);

    GEOSGeometry *inputGeom = GEOSGeomFromWKT("POINT (30 10)");

    if (inputGeom == NULL) {
        fprintf(stderr, "NULL GEOM");
        return 0;
    }

    printf("%s\n", GEOSGeomToWKT(inputGeom));

    finishGEOS();
    return 0;
}

...