Неопределенная ссылка при использовании gcc

Пытаясь скомпилировать этот код, вы продолжаете получать ошибки компилятора "неопределенная ссылка на...". Я не уверен, что происходит. Мне сказали, что вам не нужно включать ссылку на файл «.c», если вы ссылаетесь на его файл «.h».

Моя команда терминала: gcc Main.c semaphore.o -L. -lst -o test

/tmp/ccGSIjXz.o: In function `main':
HW3.c:(.text+0x15): undefined reference to `init_buffer'
HW3.c:(.text+0x26): undefined reference to `init_buffer'
HW3.c:(.text+0x37): undefined reference to `init_buffer'
/tmp/ccGSIjXz.o: In function `Thread1':
HW3.c:(.text+0x159): undefined reference to `c_deposit'
/tmp/ccGSIjXz.o: In function `Thread2':
HW3.c:(.text+0x18c): undefined reference to `c_remove'
HW3.c:(.text+0x1b9): undefined reference to `c_deposit'
/tmp/ccGSIjXz.o: In function `Thread3':
HW3.c:(.text+0x1e8): undefined reference to `c_remove'
HW3.c:(.text+0x206): undefined reference to `c_remove'
HW3.c:(.text+0x21a): undefined reference to `c_remove'
HW3.c:(.text+0x238): undefined reference to `c_deposit'
HW3.c:(.text+0x252): undefined reference to `c_deposit'
/tmp/ccGSIjXz.o: In function `Thread4':
HW3.c:(.text+0x28c): undefined reference to `c_remove'
collect2: ld returned 1 exit status

Вот код:

Основной.с:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "st.h"
#include "buffer.h"

#define MAX_CHARS 81
#define BUFF_SIZE 12
#define NULL_CHAR
typedef struct {
}ThreadInit;

static buffer *buffer1;
static buffer *buffer2;
static buffer *buffer3;

void *Thread1();
void *Thread2();
void *Thread3();
void *Thread4();

int main(int argc, char const *argv[])
{
    buffer1=init_buffer(BUFF_SIZE);
    buffer2=init_buffer(BUFF_SIZE);
    buffer3=init_buffer(BUFF_SIZE);

    ThreadInit thread1={};
    ThreadInit thread2={};
    ThreadInit thread3={};
    ThreadInit thread4={};

    if (st_thread_create(Thread1(), &thread1, 0, 0) == NULL) {
        perror("st_thread_create failed for thread 1");
        exit(EXIT_FAILURE);
    }

    if (st_thread_create(Thread2(), &thread2, 0, 0) == NULL) {
        perror("st_thread_create failed for thread 2");
        exit(EXIT_FAILURE);
    }
    if (st_thread_create(Thread3(), &thread3, 0, 0) == NULL) {
        perror("st_thread_create failed for thread 3");
        exit(EXIT_FAILURE);
    }
    if (st_thread_create(Thread4(), &thread4, 0, 0) == NULL) {
        perror("st_thread_create failed for thread 4");
        exit(EXIT_FAILURE);
    }


    return 0;
}
void *Thread1()
{
    int c;
    while (1)
    {
        c=fgetc(stdin);
        c_deposit(buffer1,c);
        if(c==EOF)
        {
            break;
        }
    }
    st_thread_exit(NULL);
    return NULL;
}
void *Thread2(void *state)
{
    int c;
    while(1)
    {

        c=c_remove(buffer1);
        if(c==EOF)
        {
            break;
        }
        if(c=='\n')
        {
            c=' ';
        }
        c_deposit(buffer2,c);
    }
    st_thread_exit(NULL);
    return NULL;

}
void *Thread3(void *state)
{
    int c;
    while(1)
    {
        c=c_remove(buffer2);
        if(c==EOF)
        {
            break;
        }
        if(c=='*' && c_remove(buffer2)=='*')
        {
            c_remove(buffer2);
            c='^';
            c_deposit(buffer3,c);
        }
        else
        {
            c_deposit(buffer3,c);
        }
    }
    st_thread_exit(NULL);
    return NULL;
}
void *Thread4(void *state)
{
    int counter=0;
    int c;
    char output[MAX_CHARS];
    output[MAX_CHARS-1]='\0';
    while(1)
    {
        c=c_remove(buffer3);
        if(c==EOF)
        {
            break;
        }
        else
        {
            output[counter]=c;
            if(counter==80)
            {
                printf("%s",output);
                counter=-1;
                memset(output,'\0',BUFF_SIZE);
            }
            counter++;
        }
    }
    st_thread_exit(NULL);
    return NULL;
}

Буфер.c:

#include <stdio.h>
#include <stdlib.h>
#include "semaphore.h"
#include "buffer.h"

buffer *init_buffer(int size)
{

    buffer *new_Buffer;
    new_Buffer=malloc((sizeof(buffer)));

    createSem(new_Buffer->emptyBuffer, size);
    new_Buffer->emptyBuffer=malloc(sizeof(semaphore));

    createSem(new_Buffer->fullBuffer, 0);
    new_Buffer->fullBuffer=malloc(sizeof(semaphore));

    new_Buffer->chars=malloc(sizeof(char)*size);

    new_Buffer->size=size;

    new_Buffer->nextIn=0;
    new_Buffer->nextOut=0;

    return new_Buffer;
}

void c_deposit(buffer *buffer, char c)
{
    down(buffer->emptyBuffer);
    buffer->chars[buffer->nextIn]=c;
    buffer->nextIn=(buffer->nextIn+1)%buffer->size;
    up(buffer->fullBuffer);
}
int c_remove(buffer *buffer)
{
    int c;
    down(buffer->fullBuffer);
    c=buffer->chars[buffer->nextOut];
    buffer->nextOut=(buffer->nextOut+1)%buffer->size;
    up(buffer->emptyBuffer);
    return c;
}

буфер.ч:

#include <stdio.h>
#include "semaphore.h"

typedef struct{
    semaphore emptyBuffer;
    semaphore fullBuffer;
    int nextIn;
    int nextOut;
    int size;
    char *chars;
}buffer;

void c_deposit(buffer *buffer, char c);
int c_remove(buffer *buffer);
buffer *init_buffer(int size);

person Community    schedule 09.10.2013    source источник
comment
это ошибка компоновщика. вы забыли добавить buffer.c в список файлов?   -  person akonsu    schedule 09.10.2013
comment
Пожалуйста, опубликуйте свою командную строку Makefile или gcc.   -  person Jonathon Reinhart    schedule 09.10.2013
comment
Только что добавил, понял, что может быть полезно   -  person    schedule 09.10.2013


Ответы (3)


Изменять

gcc Main.c semaphore.o -L. -lst -o test

To

gcc Main.c semaphore.o buffer.c -L. -lst -o test
person Charlie Burns    schedule 09.10.2013
comment
пишет нет такого файла или каталога - person ; 09.10.2013
comment
Хорошо, это сработало, но теперь я также получаю сумасшедшие ошибки, я должен просто опубликовать еще один вопрос? - person ; 09.10.2013
comment
@sreya, потратьте немного времени и попробуйте разобраться в них сами. Если вы не можете, да, я думаю, разместить еще один вопрос. Попробуйте сократить проблему до самого маленького примера, который показывает ошибку. - person Charlie Burns; 09.10.2013

Мне сказали, что вам не нужно включать ссылку на файл «.c», если вы ссылаетесь на его файл «.h».

Это неправильно. Каждый .c исходный файл должен быть скомпилирован в .o объектный файл. Затем объектные файлы связываются вместе, чтобы сформировать окончательный двоичный файл. Вы можете позволить gcc сделать это за вас, просто указав все ваши файлы .c в командной строке gcc.

Единственное, что делает #include "buffer.h", это копирует содержимое этого файла .h в текущий файл .c. Вы делаете это, чтобы файл .c знал обо всех типах, на которые ссылаются, и прототипах функций, которые вы будете вызывать (чтобы он мог сгенерировать правильный код для вызова).

В этом случае вам просто нужно добавить buffer.c в командную строку gcc.

person Jonathon Reinhart    schedule 09.10.2013
comment
когда я говорю ссылка, я имел в виду #include "buffer.h" и #include "buffer.c" - person ; 09.10.2013
comment
НИКОГДА #include "xxx.c" - person Jonathon Reinhart; 09.10.2013
comment
хорошо, это то, что я имел в виду в предложении, которое вы выделили изначально - person ; 09.10.2013

пытаться

gcc Main.c buffer.c semaphore.o -L. -lst -o test

вы можете добавить прототип для init_buffer в buffer.h:

buffer *init_buffer(int size);
person akonsu    schedule 09.10.2013
comment
Я действительно сделал, плохая копия / вставка - person ; 09.10.2013