Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-09-2007, 15: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, 15: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, 16: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, 16: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, 16: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, 16: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, 16: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, 16: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, 16: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, 16: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, 17: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, 17: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, 18: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 30-09-2007, 00: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, 09: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, 11: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 11:40.
nico88desmo è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2007, 14: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, 15: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


Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
Steam Machine partirà da circa 1....
Google limita i riassunti di AI Overview...
iPhone Air 2: più autonomia e un ...
MacBook Pro con chip M4, 24GB di RAM e 1...
Apple sceglie Google Gemini per potenzia...
NVIDIA ed Eli Lilly: un laboratorio AI c...
Un PC da gaming costa troppo? Con questa...
Non solo iPhone: è questa la vera...
Rigenerazione territoriale: Huawei trasf...
Batteria e-bike a rischio incendio? L'in...
Assetto Corsa Evo: i dintorni del Nordsc...
HP pronta a introdurre memorie cinesi in...
Apple supera Samsung e conquista la lead...
L'UE vuole il nostro feedback sull'open ...
Polestar chiude in crescita il 2025, nuo...
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: 08:02.


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