Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 06-06-2010, 16:25   #1
Damage92
Senior Member
 
L'Avatar di Damage92
 
Iscritto dal: Sep 2008
Città: Roma
Messaggi: 1382
[C++] Usare librerie del C

Sto imparando il C++ conoscendo il C.
Voglio "importare" una funzione scritta in C nel programma che sto scrivendo, che però utilizza una libreria esterna. Dunque mi chiedevo se è possibile includere direttamente la libreria che usavo il C, oppure se devo per forza usare il wrapper per C++.
Il wrapper serve solo per rendere la libreria in stile OOP, giusto?

Un'altra cosa che c'entra poco col titolo: ho letto cosa sono i namespace, ma cosa succede se due librerie hanno namespace con nomi uguali? Quando uso l'istruzione "using namespace" come fa il compilatore a capire a quale libreria mi riferisco?
Damage92 è offline   Rispondi citando il messaggio o parte di esso
Old 07-06-2010, 01:53   #2
sprik
Junior Member
 
Iscritto dal: Mar 2009
Messaggi: 27
Puoi includere l'header della libreria C che vuoi utilizzare con extern

extern "C" {
#include "libreriaC.h"
}


Se ci sono più namespace con lo stesso nome il compilatore ti darà un errore per dichiarazione multipla di namespace, o perlomeno così ricordo.
sprik è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2010, 19:35   #3
Damage92
Senior Member
 
L'Avatar di Damage92
 
Iscritto dal: Sep 2008
Città: Roma
Messaggi: 1382
Grazie per la risposta
Da quello che leggo extern serve solo per le librerie non di sistema, giusto?

Approfitto per un altro chiarimento
cosa significa l'uso di "<" e ">" nei tipi di variabili? Per esempio:
vector<string>
Dove (penso) string è una classe, mentre vector non so...
Damage92 è offline   Rispondi citando il messaggio o parte di esso
Old 09-06-2010, 00:40   #4
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da Damage92 Guarda i messaggi
Un'altra cosa che c'entra poco col titolo: ho letto cosa sono i namespace, ma cosa succede se due librerie hanno namespace con nomi uguali? Quando uso l'istruzione "using namespace" come fa il compilatore a capire a quale libreria mi riferisco?
non esiste il fatto che due namespaces abbiano lo stesso nome: il compilatore li considera lo stesso namespace eventualmente riaperto una seconda volta. se due headers che includi dichiarano simboli all'interno di namespaces omonimi il risultato é che tu hai un unico namespace in cui sono dichiarati i simboli di entrambi gli headers, i quali naturalmente possono anche collidere ed impedire la compilazione.



Quote:
Originariamente inviato da Damage92 Guarda i messaggi
Approfitto per un altro chiarimento
cosa significa l'uso di "<" e ">" nei tipi di variabili? Per esempio:
vector<string>
Dove (penso) string è una classe, mentre vector non so...
le parentesi ad angolo vengono usate per definire ed istanziare i templates, immagino che tu non li abbia ancora fatti. std::vector é una template class delle STL; qui ne trovi il reference: http://www.cplusplus.com/reference/stl/vector/
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 09-06-2010, 18:18   #5
Damage92
Senior Member
 
L'Avatar di Damage92
 
Iscritto dal: Sep 2008
Città: Roma
Messaggi: 1382
Grazie mille!
Damage92 è offline   Rispondi citando il messaggio o parte di esso
Old 09-06-2010, 19:49   #6
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Ma extern serve davvero?
Generalmente mi limito ad includere la roba e funziona; vale per OpenAL, OpenGL, nedmalloc, FreeImage, FreeType etc.
Sarà che ormai non esistono più librerie "vere" per C
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 10-06-2010, 01:01   #7
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da Tommo Guarda i messaggi
Ma extern serve davvero?
extern serve ad evitare il mangling dei nomi; serve se i simboli dichiarati devono ad esempio essere importati da una DLL che li esporta con nomi non decorati.

in generale quando si esportano simboli da una DLL scritta in C++ sarebbe bene esportarli sempre in forma non decorata perché le convenzioni di mangling non sono standardizzate (nonostante il mangling sia una evidente necessitá implementativa dei compilatori C++) e quindi variano da un compilatore all'altro: per esempio non é possibile importare col MinGW simboli decorati esportati da una DLL scritta in Visual C++, bisogna usare per forza extern "C".
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 10-06-2010, 02:01   #8
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da Tommo Guarda i messaggi
Ma extern serve davvero?
Generalmente mi limito ad includere la roba e funziona; vale per OpenAL, OpenGL, nedmalloc, FreeImage, FreeType etc.
Sarà che ormai non esistono più librerie "vere" per C
Si' e' necessario. Non e' affatto garantito che i simboli esportati dal compilatore C e da quello C++ siano uguali, anche compilando lo stesso identico codice.
Ad esempio con gcc sotto linux quando il compilatore trova una dichiarazione tipo
Codice:
int foo(int)
generera' del codice che esporta nel caso del C il simbolo 'foo' e nel caso del C++ il simbolo '_Z3fooi' (o comunque una altra rappresentazione nota al compilatore.
Quindi quando devi linkare in C++ funzioni scritte in C devi indicarlo al compilatore.

Spesso non si nota perche' le maggiori librerie inseriscono delle guardie opportune negli header per evitare all'utilizzatore l'impacci di farlo lui.
Ad esempio sotto linux l'header di FreeImage ha all'inizio il seguente spezzone di codice:
Codice:
#ifdef __cplusplus
extern "C" {
#endif
Immagino che per VS si operi in modo analogo.
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 10-06-2010, 03:27   #9
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da marco.r Guarda i messaggi
Immagino che per VS si operi in modo analogo.
sissignore
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 10-06-2010, 11:49   #10
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Ok, quindi mi hanno "salvato" loro :ads:
Grazie per la delucidazione
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Un 2026 da dimenticare per le CPU? Anche...
Samsung integra Perplexity AI in Galaxy ...
'Una telefonata allunga la vita': lo spo...
Gli smart ring di Oura conquistano Washi...
Windows 10 ESU: Microsoft annuncia l'est...
Game Boy LEGO a 45€: il mito Nintendo an...
Andrea Pignataro supera Giovanni Ferrero...
La Cina vieta i volanti a cloche (yoke) ...
Come dovrebbe essere Task Manager second...
Perché HONOR Magic 8 Lite è...
A soli 149€ Roborock Q7 M5 con 10.000 Pa...
Google Pixel 10 a 563€: Android puro e t...
Altman frena sui datacenter AI orbitali:...
Addio RAM cinese a basso costo: 32 GB DD...
Jony Ive e OpenAI preparano uno smart sp...
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: 12:15.


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