Ошибка компиляции программы на C, которая вызывает функцию C , объявленную в заголовочном файле и определенную в отдельном cpp-файле

#c #c #extern

#c #c #внешний

Вопрос:

Я пытаюсь вызвать функцию C в программе на C. Я объявил функцию в файле .h следующим образом- data_fields.h:

 #ifdef __cplusplus
extern "C"
{
#endif
    char GetCharFromHexAscii(char *);
#ifdef __cplusplus
}
#endif
  

И я вызываю GetCharFromHexAscii() в моем файле .c следующим образом-
GUIForRenamer.c:

 #include<stdio.h>
#include<gtk/gtk.h>
#include<unistd.h>
#include<string.h>
#include<ctype.h>
#include"data_fields.h"
char * AsciiDecode(char *Path)
{
    int k = 0;
    char *convertedPath, *asciiChar;
    convertedPath = (char *)malloc(strlen(Path)   1 * sizeof(char));
    asciiChar = (char *)malloc(3 * sizeof(char));
    for(int i = 0; Path[i] != ''; i  )
        convertedPath[k  ] = GetCharFromHexAscii(asciiChar);
    return convertedPath;
}
  

Определение функции C в .cpp выглядит следующим образом-
LibFunc.cpp:

 #include<iostream>
#include<cstdlib>
#include"data_fields.h"
char GetCharFromHexAscii(char *asciiChar)
{
    int hexVal = stoi(asciiChar, 0, 16);
    return (char)hexVal;
}
  

Вот команда, которую я использую для компиляции моего кода на C-

 gcc GUIForRenamer.c -lm `pkg-config --libs --cflags gtk -3.0` -export-dynamic FileExtensionRenamer.c LibFunc.cpp
  

Но компиляция завершается неудачей со следующей ошибкой-

 LibFunc.cpp: In function ‘char GetCharFromHexAscii(char*)’:
LibFunc.cpp:7:15: error: ‘stoi’ was not declared in this scope
  int hexVal = stoi(asciiChar, 0, 16);
               ^~~~
LibFunc.cpp:7:15: note: suggested alternatives:
In file included from /usr/include/c  /7/string:52:0,
                 from /usr/include/c  /7/bits/locale_classes.h:40,
                 from /usr/include/c  /7/bits/ios_base.h:41,
                 from /usr/include/c  /7/ios:42,
                 from /usr/include/c  /7/ostream:38,
                 from /usr/include/c  /7/iostream:39,
                 from LibFunc.cpp:1:
/usr/include/c  /7/bits/basic_string.h:6477:3: note:   ‘std::__cxx11::stoi’
   stoi(const wstringamp; __str, size_t* __idx = 0, int __base = 10)
   ^~~~
/usr/include/c  /7/bits/basic_string.h:6477:3: note:   ‘std::__cxx11::stoi’
  

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

Кто-нибудь может помочь мне выяснить, что еще можно для этого сделать?

Основываясь на приведенных ниже предложениях, я обновил код в LibFunc.cpp следующим образом-

 #include<iostream>
#include<cstdlib>
#include"data_fields.h"
#include<string>
using namespace std;
char GetCharFromHexAscii(char *asciiChar)
{
    int hexVal = stoi(asciiChar, 0, 16);
    return (char)hexVal;
}
  

При компиляции этого кода у меня возникли следующие проблемы-

 /tmp/ccr7aSCZ.o: In function `GetCharFromHexAscii':
LibFunc.cpp:(.text 0x24): undefined reference to `std::allocator<char>::allocator()'
LibFunc.cpp:(.text 0x3b): undefined reference to `std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >::basic_string(char const*, std::allocator<char> constamp;)'
LibFunc.cpp:(.text 0x60): undefined reference to `std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >::~basic_string()'
LibFunc.cpp:(.text 0x6c): undefined reference to `std::allocator<char>::~allocator()'
LibFunc.cpp:(.text 0x8f): undefined reference to `std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >::~basic_string()'
LibFunc.cpp:(.text 0xa0): undefined reference to `std::allocator<char>::~allocator()'
/tmp/ccr7aSCZ.o: In function `__static_initialization_and_destruction_0(int, int)':
LibFunc.cpp:(.text 0xe0): undefined reference to `std::ios_base::Init::Init()'
LibFunc.cpp:(.text 0xf5): undefined reference to `std::ios_base::Init::~Init()'
/tmp/ccr7aSCZ.o: In function `std::__cxx11::stoi(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > constamp;, unsigned long*, int)':
LibFunc.cpp:(.text._ZNSt7__cxx114stoiERKNS_12basic_stringIcSt11char_traitsIcESaIcEEEPmi[_ZNSt7__cxx114stoiERKNS_12basic_stringIcSt11char_traitsIcESaIcEEEPmi] 0x1b): undefined reference to `std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >::c_str() const'
/tmp/ccr7aSCZ.o: In function `int __gnu_cxx::__stoa<long, int, char, int>(long (*)(char const*, char**, int), char const*, char const*, unsigned long*, int)':
LibFunc.cpp:(.text._ZN9__gnu_cxx6__stoaIlicJiEEET0_PFT_PKT1_PPS3_DpT2_EPKcS5_PmS9_[_ZN9__gnu_cxx6__stoaIlicJiEEET0_PFT_PKT1_PPS3_DpT2_EPKcS5_PmS9_] 0x62): undefined reference to `std::__throw_invalid_argument(char const*)'
LibFunc.cpp:(.text._ZN9__gnu_cxx6__stoaIlicJiEEET0_PFT_PKT1_PPS3_DpT2_EPKcS5_PmS9_[_ZN9__gnu_cxx6__stoaIlicJiEEET0_PFT_PKT1_PPS3_DpT2_EPKcS5_PmS9_] 0xa3): undefined reference to `std::__throw_out_of_range(char const*)'
/tmp/ccr7aSCZ.o:(.data.rel.local.DW.ref.__gxx_personality_v0[DW.ref.__gxx_personality_v0] 0x0): undefined reference to `__gxx_personality_v0'
collect2: error: ld returned 1 exit status
  

Я думал, что это проблема, вызванная передачей char * в качестве параметра вместо передачи объекта string в функцию stoi. Итак, я преобразовал char * в объект string и передал его функции. Но это не устранило ошибку и по-прежнему вызывало ту же проблему с компиляцией.

Кто-нибудь, пожалуйста, может помочь мне понять, почему я получаю эту ошибку, а также предложить способ ее устранения?

Комментарии:

1. Вам нужно скомпилировать C и C отдельно, а затем связать их вместе.

2. stoi объявлена в <string> и находится в std пространстве имен.

3. malloc(strlen(Path) 1 * sizeof(char)) работает только потому, что по определению sizeof (char) является 1 … помните, что умножение имеет приоритет над сложением, поэтому ваше выражение эквивалентно strlen(Path) (1 * sizeof(char)) == strlen(Path) sizeof(char) == strlen(Path) 1 … если вы действительно хотите сохранить избыточное умножение на 1, сделайте malloc((strlen(Path) 1) * sizeof(char)) … подчеркнем: malloc(strlen(Path) 1 * sizeof(char)) неверно.

4. @pmg: Спасибо, что исправили меня.

Ответ №1:

Вы вызываете функцию stoi . Вы не определили такую функцию.

Как также было замечено в сообщении об ошибке, возможно, вместо этого вы намеревались вызвать std::stoi функцию из стандартной библиотеки C . Обратите внимание, что она объявлена в std пространстве имен. Кроме того, вы должны включить заголовок, который ее объявляет ( <string> ).


Кроме того, вам может потребоваться установить связь со стандартной библиотекой C . Это произошло бы автоматически, если бы вы использовали g интерфейс вместо gcc .

Комментарии:

1. Благодарю вас за предложение использовать std, поскольку это помогло мне продвинуться на шаг дальше. Но компиляция с помощью g не помогает мне решить мои проблемы, скорее, это вызывает у меня больше проблем с компиляцией, поскольку мои другие файлы являются файлами .c и правильно скомпилированы только с использованием gcc.

2. @Priya. Общий компилятор файлов C с g и C файлов с gcc.

Ответ №2:

Функция stoi расположена в <string> заголовке (не string.h, вы можете проверить https://en.cppreference.com/w/cpp/string/basic_string/stol).

Поскольку в вашем коде ее нет using namespace std , вам следует изменить свой вызов на stoi на std::stoi

Окончательный рабочий код может выглядеть примерно так

 #include <string>
char GetCharFromHexAscii(char *asciiChar)
{
    int hexVal = std::stoi(asciiChar, 0, 16);
     return (char)hexVal;
}
  

Комментарии:

1. Спасибо за предложение использовать std, поскольку это помогло мне продвинуться на шаг дальше, но я получил другой набор ошибок. Я обновил приведенный выше вопрос следующим набором ошибок. Пожалуйста, проверьте и дайте мне знать, если вы сможете мне с этим помочь.