Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-09-2007, 14:20   #1
nico88desmo
Senior Member
 
Iscritto dal: Jul 2006
Messaggi: 1568
[C] gcc - multiple definition of...

Buongiorno!

Durante la compilazione di un programmino in C, il compilatore gcc mi dà in output questo errorino:
Codice:
gcc -o main_mate main_mate.c lib.a 
lib.a(lib_mate.o):(.data+0x0): multiple definition of `LIB_SIMBOLI'
/tmp/ccwhL9qR.o:(.data+0x0): first defined here
collect2: ld returned 1 exit status
I file sono 3:
- main_mate.c = programmino dove viene lanciato il programma;
- lib_mate.h = libreria che contiene strutture e dichirazione funzioni;
- lib_mate.c = sorgente dove viene scritto il corpo delle funzioni della libreria:

Per la compilazione faccio questi passaggi:
1) gcc -c -o lib_mate.o lib_mate.c
2) ar r lib.a lib_mate.o
3) gcc -c -o main_mate main_mate.c
4) gcc -o main_mate main_mate.c lib.a

L'errore significa che ci sono più definizioni di `LIB_SIMBOLI` ma quest'ultimo è stato definito solamente nel sorgente "lib_mate.h".
Cosa potrebbe essere allora???
nico88desmo è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 14:56   #2
Torav
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 558
se non hai usato #ifndef e #define forse rischi di includere più volte lo stesso .h e quindi in effetti il compilatore vede la roba definita 2 volte! non so eh...senza vedere i sorgenti non so essere più preciso
Torav è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 15:00   #3
nico88desmo
Senior Member
 
Iscritto dal: Jul 2006
Messaggi: 1568
Quote:
Originariamente inviato da Torav Guarda i messaggi
se non hai usato #ifndef e #define forse rischi di includere più volte lo stesso .h e quindi in effetti il compilatore vede la roba definita 2 volte! non so eh...senza vedere i sorgenti non so essere più preciso
Io ho definito così la libreria all'interno del file `lib_mate.h`;
Codice:
#ifndef __lib_mate_h_
#define __lib_mate_h_
e ora ho provato a togliere i 2 underscore, quindi risulta così:
Codice:
#ifndef lib_mate_h
#define lib_mate_h
però niente..mi dà sempre lo stesso errore..
nico88desmo è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 15:26   #4
Torav
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 558
scusami ma non capisco il terzo passaggio..in teoria tu compili la tua libreria e va bene, poi dovresti semplicemente compilare il programma principale, quello che ha il main() per intenderci, e poi fai una cosa tipo:

gcc -o main_mate main_mate.c -llib -L.

con -l gli dici dove cercare la libreria (che in questo caso è lib.a, bisogna passare dopo il -l semplicemente il nome del .a senza l'estensione)
con -L invece gli dici dove cercare l'header (in questo caso . perchè è nella dir corrente)

se invece vuoi evitarti il fatto di fare una libreria basta fare

gcc -o main_mate main_mate.c lib_mate.c
Torav è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 15:29   #5
nico88desmo
Senior Member
 
Iscritto dal: Jul 2006
Messaggi: 1568
L'errore è provocato dalle seguente riga di codice
Codice:
char *(LIB_SIMBOLI[]) = {"+","-","*","/","sin","cos","tan","asin","acos","atan","log","^","%"};
Vorrei definire un vettore all'interno del file header?
Come si fa?
nico88desmo è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 15:31   #6
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da nico88desmo Guarda i messaggi
L'errore significa che ci sono più definizioni di `LIB_SIMBOLI` ma quest'ultimo è stato definito solamente nel sorgente "lib_mate.h".
Nei file di header NON si devono fare definizioni di variabili o funzioni.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 15:34   #7
nico88desmo
Senior Member
 
Iscritto dal: Jul 2006
Messaggi: 1568
Quote:
Originariamente inviato da andbin Guarda i messaggi
Nei file di header NON si devono fare definizioni di variabili o funzioni.
Ma nemmeno le costanti?
nico88desmo è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 15:38   #8
nico88desmo
Senior Member
 
Iscritto dal: Jul 2006
Messaggi: 1568
Quote:
Originariamente inviato da Torav Guarda i messaggi
scusami ma non capisco il terzo passaggio..in teoria tu compili la tua libreria e va bene, poi dovresti semplicemente compilare il programma principale, quello che ha il main() per intenderci, e poi fai una cosa tipo:

gcc -o main_mate main_mate.c -llib -L.

con -l gli dici dove cercare la libreria (che in questo caso è lib.a, bisogna passare dopo il -l semplicemente il nome del .a senza l'estensione)
con -L invece gli dici dove cercare l'header (in questo caso . perchè è nella dir corrente)

se invece vuoi evitarti il fatto di fare una libreria basta fare

gcc -o main_mate main_mate.c lib_mate.c
Si, infatti il terzo passaggio ho notato che non serve a nulla
Per il gcc.... -l è per le librerie statiche o non fà differenza tra statiche e dinamiche?
nico88desmo è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 15:42   #9
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da nico88desmo Guarda i messaggi
Ma nemmeno le costanti?
Quella LIB_SIMBOLI non è una costante ... è una variabile (e tra l'altro le parentesi tonde non servono).

Il problema è semplice: se in un file di header si fanno definizioni che allocano memoria come appunto definire una variabile o una funzione, allora tali definizioni fanno poi parte del modulo oggetto compilato. Che succede se al linker arrivano più moduli oggetto che contengono simboli con lo stesso nome?
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 15:48   #10
nico88desmo
Senior Member
 
Iscritto dal: Jul 2006
Messaggi: 1568
Quote:
Originariamente inviato da andbin Guarda i messaggi
Quella LIB_SIMBOLI non è una costante ... è una variabile (e tra l'altro le parentesi tonde non servono).

Il problema è semplice: se in un file di header si fanno definizioni che allocano memoria come appunto definire una variabile o una funzione, allora tali definizioni fanno poi parte del modulo oggetto compilato. Che succede se al linker arrivano più moduli oggetto che contengono simboli con lo stesso nome?
Succede Caos
Se io volessi dichiarare quel vettore e renderlo visibile a più sorgenti, potrei fare così?
Prima lo dichiaro in un sorgente e successivamente negli altri sorgenti .c, farlo riconoscere mediante la parole chiave "extern"..
nico88desmo è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 16:22   #11
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da nico88desmo Guarda i messaggi
Prima lo dichiaro in un sorgente e successivamente negli altri sorgenti .c, farlo riconoscere mediante la parole chiave "extern"..
Appunto ... si fa la definizione in un sorgente .c e poi negli altri sorgenti (o meglio magari in un header incluso dai sorgenti) si fa una allusione alla variabile/funzione tramite extern (per i prototipi di funzione extern è superfluo).
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 16:45   #12
nico88desmo
Senior Member
 
Iscritto dal: Jul 2006
Messaggi: 1568
Quote:
Originariamente inviato da andbin Guarda i messaggi
Appunto ... si fa la definizione in un sorgente .c e poi negli altri sorgenti (o meglio magari in un header incluso dai sorgenti) si fa una allusione alla variabile/funzione tramite extern (per i prototipi di funzione extern è superfluo).
Perfetto. Fatto così e funziona tutto!
nico88desmo è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 17:32   #13
recoil
Senior Member
 
L'Avatar di recoil
 
Iscritto dal: Jul 2002
Città: Milano
Messaggi: 19148
in alcuni casi (non nel tuo) un errore del genere può essere causato da qualche inesattezza nel Makefile
io ad esempio una volta ho perso 10 minuti prima di capire che mettevo lo stesso .o due volte nel Makefile, con una sfilza impressionante di errori "multiple definition of..."
recoil è offline   Rispondi citando il messaggio o parte di esso
Old 29-09-2007, 23:36   #14
Andrea16v
Senior Member
 
L'Avatar di Andrea16v
 
Iscritto dal: Mar 2003
Messaggi: 3852
Mi accodo al thread per chiedere: anche nel caso di una variabile intera condivisa tra piu' files, non è buona norma dichiararla nel file.h incluso da tutti ? Mi servirebbe sia visibile da tutti i files che compongono il programma, senza passarla come parametro da un metodo all'altro...
__________________
Cerco fotocamera con buono zoom!! CLICCA!
° Moderatore del Forum Ufficiale di ElaborarE (responsabile sezione HI-FI e Car Audio) °
Andrea16v è offline   Rispondi citando il messaggio o parte di esso
Old 30-09-2007, 08:16   #15
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
edit scusate
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 30-09-2007, 10:38   #16
nico88desmo
Senior Member
 
Iscritto dal: Jul 2006
Messaggi: 1568
Quote:
Originariamente inviato da Andrea16v Guarda i messaggi
Mi accodo al thread per chiedere: anche nel caso di una variabile intera condivisa tra piu' files, non è buona norma dichiararla nel file.h incluso da tutti ? Mi servirebbe sia visibile da tutti i files che compongono il programma, senza passarla come parametro da un metodo all'altro...
Io la metterei nel file .h

Codice:
#define VARIABILE_INTERA 1000
Così facendo però non hai una variabile...è una define che è diverso.
Se la variabile che ti serve è costante allora farei così, altrimenti no.
Il mio problema era che dovevo dichiarare un vettore di stringhe...per questo ho dovuto dichiararlo nel file .c

Ultima modifica di nico88desmo : 30-09-2007 alle 10:40.
nico88desmo è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2007, 13:15   #17
recoil
Senior Member
 
L'Avatar di recoil
 
Iscritto dal: Jul 2002
Città: Milano
Messaggi: 19148
la dichiari in uno e poi la metti come extern negli altri
non è bello ma in alcuni casi è necessario
recoil è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2007, 14:22   #18
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
In alternativa si può usare (nei .h)
Codice:
__attribute__((section(".gnu.linkonce"))) int var;
ottenendo un codice di assoluta nonportabilità e di dubbia leggibilità.

E' meglio implementarla in un file sorgente e dichiararla come extern negli header.
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Cos'è RSL, il nuovo standard che ...
Nissan Micra EV: da 29.500 a oltre 36.00...
Processo Microsoft-ValueLicensing: cosa ...
L'edizione limitata più ambita da...
Lo sviluppatore di MSI Afterburner svela...
Quando l'AI diventa maestro: così...
Sony WH-1000XM6 già scontate su A...
NVIDIA chiede più velocità...
Windows 11 in soli 2,8 GB: con questo sc...
Panico in casa HYTE: ritirato dal mercat...
OPPO Reno14, debutto tra rooftoop esclus...
3DAIQ, il progetto di Concept Reply e TE...
Il parlamento francese contro TikTok: '&...
Apple Watch SE 2ª gen. Cellular a soli 2...
MotoE sospesa dopo il 2025: fine tempora...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 23:51.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v