nm: “U” символ не определено

Когда я nm на одном из моего освобождаю:

nm libmylib.so

Я получаю строку как это

             U _ZNSs4_Rep20_S_empty_rep_storageE@@GLIBCXX_3.4

Я проверил страницу справочника на nm, и я получил "U", символ не определен. Что действительно означает неопределенный символ?

Если это действительно не определено, то, почему nm сообщает об этом вообще?

49
задан bbazso 24 February 2010 в 11:33
поделиться

3 ответа

Неопределенный символ - это символ, который использует библиотека, но не был определен ни в одном из объектных файлов, которые использовались при создании библиотеки.

Обычно символ определяется в другой библиотеке, которую также необходимо связать с вашим приложением. В качестве альтернативы символ не определен, потому что вы забыли построить код, определяющий символ, или вы забыли включить объектный файл с этим символом в свою библиотеку.

В вашем случае он выглядит как символ из библиотеки C вашей реализации, поэтому вы ожидаете, что он не определен в вашей собственной библиотеке. Он будет определен в вашей libc.so, где бы он ни находился, возможно, в / usr / lib.

43
ответ дан 7 November 2019 в 11:56
поделиться

Это означает, что библиотека ссылается на этот символ ( std :: basic_string , std :: allocator > :: _ Rep :: _ S_empty_rep_storage в этом случае? ), но это не определяет его; какая-то часть программы, с которой вы ее связываете, или какая-то другая библиотека должна это делать. Если вы действительно хотели определить его в своей библиотеке, это означает, что вы не связали объектный файл с определением этого символа с остальной частью кода библиотеки.

0
ответ дан 7 November 2019 в 11:56
поделиться

Можно задать функцию обратного вызова для получения входящих порций данных с помощью curl _ easy _ setopt (curl, CURLOPT_WRITEFUNCTION, myfunc);

Обратный вызов будет принимать пользовательский аргумент, который можно задать с помощью curl _ easy _ setopt (curl, CURLOPT_WRITEDATA, p)

Вот фрагмент кода, который передает буфер structure len} к функции обратного вызова и увеличивает этот буфер для каждого вызова с помощью realloc ().

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <curl/curl.h>

struct string {
  char *ptr;
  size_t len;
};

void init_string(struct string *s) {
  s->len = 0;
  s->ptr = malloc(s->len+1);
  if (s->ptr == NULL) {
    fprintf(stderr, "malloc() failed\n");
    exit(EXIT_FAILURE);
  }
  s->ptr[0] = '\0';
}

size_t writefunc(void *ptr, size_t size, size_t nmemb, struct string *s)
{
  size_t new_len = s->len + size*nmemb;
  s->ptr = realloc(s->ptr, new_len+1);
  if (s->ptr == NULL) {
    fprintf(stderr, "realloc() failed\n");
    exit(EXIT_FAILURE);
  }
  memcpy(s->ptr+s->len, ptr, size*nmemb);
  s->ptr[new_len] = '\0';
  s->len = new_len;

  return size*nmemb;
}

int main(void)
{
  CURL *curl;
  CURLcode res;

  curl = curl_easy_init();
  if(curl) {
    struct string s;
    init_string(&s);

    curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se");
    curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, writefunc);
    curl_easy_setopt(curl, CURLOPT_WRITEDATA, &s);
    res = curl_easy_perform(curl);

    printf("%s\n", s.ptr);
    free(s.ptr);

    /* always cleanup */
    curl_easy_cleanup(curl);
  }
  return 0;
}
-121--832627-

Если вы действительно хотите помочь своим "не таким опытным программистам", вам лучше попытаться обнаружить, когда они делают встроенный sql в свой код. Не должно быть слишком сложно написать правило FxCop, чтобы обнаружить его. Если включить его как часть процесса посткомпоновки или если у вас есть командная система, задайте правило, чтобы он не удался, они скоро его повесят.

-121--4585660-

Я думаю, что это означает именно то: undefined в этом объекте. Некоторые символы оцениваются во время выполнения; это, вероятно, один из них.

-2
ответ дан 7 November 2019 в 11:56
поделиться
Другие вопросы по тегам:

Похожие вопросы: