Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-05-2007, 15:41   #1
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
richiamare libreria c++ tramite jni

ciao a tutti, ho qualche problemuccio col richiamare una libreria c++ da java, in pratica questa libreria fornisce un'api (metodi statici di una classe), e al momento della compilazione mi genera librerie statiche (per intenderci, files .a), io ho scritto la classe java, l'header nativo l'ho fatto generare da javah, e quindi ho implementato i metodi nativi che vanno a richiamare la classe, compilo con il seguente comando:

Codice:
g++ -fPIC -I /usr/lib/java/include/ -I /usr/lib/java/include/linux/ -I /usr/local/include/tesseract/ -L/usr/local/lib/ -ltesseract_main  -shared -o OcrApi.so it_dart_ocrapi_OcrApi.cpp
ma quando vado ad includere il .so in java, con il metodo System.load, mi esce un errore come se non riuscisse a linkare i metodi della libreria in C++..ora, so benissimo che per le libreria dinamiche basta includerle nel java.library.path o nella variabile d'ambiente LD_LIBRARY_PATH il percorso alle libreria..ma con le librerie statiche come devo comportarmi?:|
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2007, 20:19   #2
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
JNI non maneggia librerie statiche, nel senso che non puoi caricare una libreria statica con System.loadLibrary. Puoi caricare una libreria dinamica collegata ad una libreria statica. La soluzione di eventuali problemi che possono sorgere in questo passaggio spetta alla lingua nativa, al suo compilatore, eccetera.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2007, 23:14   #3
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
JNI non maneggia librerie statiche, nel senso che non puoi caricare una libreria statica con System.loadLibrary. Puoi caricare una libreria dinamica collegata ad una libreria statica. La soluzione di eventuali problemi che possono sorgere in questo passaggio spetta alla lingua nativa, al suo compilatore, eccetera.
grazie per la risposta=) si, il mio problema è proprio che non riesco a linkare una libreria statica all'interno di una dinamica che poi carico con jni in java...
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 22:24   #4
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
nessuno sa aiutarmi?
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 22:33   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da cisc Guarda i messaggi
il mio problema è proprio che non riesco a linkare una libreria statica all'interno di una dinamica
Che libreria è?? Una libreria statica .a la puoi specificare per la fase di link mettendo nel comando -lnome o specificando proprio il nome completo (eventualmente di path) della libreria.

La differenza tra i due modi la spiega bene il 'man':
The only difference between using an -l option and specifying a file name is that -l surrounds library with lib and .a and searches several directories.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2007, 00:31   #6
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
Quote:
Originariamente inviato da andbin Guarda i messaggi
Che libreria è?? Una libreria statica .a la puoi specificare per la fase di link mettendo nel comando -lnome o specificando proprio il nome completo (eventualmente di path) della libreria.

La differenza tra i due modi la spiega bene il 'man':
The only difference between using an -l option and specifying a file name is that -l surrounds library with lib and .a and searches several directories.
allora, in pratica la libreria non è altro che il programma ocr tesseract, ultimamente hanno aggiunto anche una classe che fornisce diciamo l'API per poter usare tesseract da altri programmi, come potrai vedere dai parametri che passo a gcc per compilare, la libreria la includo, infatti compaiono le opzioni "-L/usr/local/lib/ -ltesseract_main", dove -L fa si che gcc vada a cercare nella cartella dove risiede la libreria,a e -ltesseract_main mi dovrebbe caricare il file libtesseract_main.a..il problema è che sembra che non lo faccia, dato che quando vado a caricare il .so risultante i java, un errore di undefined symbol, riferendosi poi chiaramente ad uno dei metodi dell'API.....ho provato cmq anche come dici tu, mettendo il nome completo..ma niente..
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2007, 09:36   #7
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da cisc Guarda i messaggi
grazie per la risposta=) si, il mio problema è proprio che non riesco a linkare una libreria statica all'interno di una dinamica che poi carico con jni in java...
Fammi capire...vuoi convertire una libreria statica in una libreria dinamica?
__________________
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
Old 17-05-2007, 11:43   #8
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Fammi capire...vuoi convertire una libreria statica in una libreria dinamica?
allora, in pratica io c'ho una lib statica, e ho fatto un wrapper diciamo, che devo usa la libreria statica, ma che deve essere caricata dinamicamente in java...non è proprio convertire la lib da statica a dinamica, dato che mi serve il wrapper che si interfacci con JNI.....
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2007, 12:15   #9
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da cisc Guarda i messaggi
allora, in pratica io c'ho una lib statica, e ho fatto un wrapper diciamo, che devo usa la libreria statica, ma che deve essere caricata dinamicamente in java...non è proprio convertire la lib da statica a dinamica, dato che mi serve il wrapper che si interfacci con JNI.....
Non puoi caricare dinamicamente una libreria statica, ma puoi inglobarla in una libreria dinamicam come credo che stai cercando di fare. Devi solo stare attento ad alcune insidie, in quanto in fase di linking gli oggetti di un archivio .a vengono scartati se il linker non vede nessun utilizzatore.
Puoi riportare la tua completa riga di comando con cui fai il link finale?
__________________
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
Old 17-05-2007, 12:59   #10
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Non puoi caricare dinamicamente una libreria statica, ma puoi inglobarla in una libreria dinamicam come credo che stai cercando di fare. Devi solo stare attento ad alcune insidie, in quanto in fase di linking gli oggetti di un archivio .a vengono scartati se il linker non vede nessun utilizzatore.
Puoi riportare la tua completa riga di comando con cui fai il link finale?
lancio solo questo

g++ -fPIC -I /usr/lib/java/include/ -I /usr/lib/java/include/linux/ -I /usr/local/include/tesseract/ -L/usr/local/lib/ -ltesseract_main -shared -o OcrApi.so it_dart_ocrapi_OcrApi.cpp

dove libtesseract_main.a è la lib statica da caricare.....
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2007, 13:30   #11
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da cisc Guarda i messaggi
lancio solo questo

g++ -fPIC -I /usr/lib/java/include/ -I /usr/lib/java/include/linux/ -I /usr/local/include/tesseract/ -L/usr/local/lib/ -ltesseract_main -shared -o OcrApi.so it_dart_ocrapi_OcrApi.cpp

dove libtesseract_main.a è la lib statica da caricare.....
Chiappato 'o moscone...
-ltesseract_main deve seguire it_dart_ocrapi_OcrApi.cpp, altrimenti viene scartato dal linker. Un bel objdump -t può mostrartelo.
Nota inoltre che gli oggetti .o di tesseract_main che non vengono riferiti da it_dart_ocrapi_OcrApi.cpp, vengono anch'essi scartati. Se il file cpp è solo un wrapper per tesseract_main, probabilmente non è il tuo caso.
__________________
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
Old 17-05-2007, 13:48   #12
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Chiappato 'o moscone...
-ltesseract_main deve seguire it_dart_ocrapi_OcrApi.cpp, altrimenti viene scartato dal linker. Un bel objdump -t può mostrartelo.
Nota inoltre che gli oggetti .o di tesseract_main che non vengono riferiti da it_dart_ocrapi_OcrApi.cpp, vengono anch'essi scartati. Se il file cpp è solo un wrapper per tesseract_main, probabilmente non è il tuo caso.
innanzitutto grazie mille! ho fatto come hai detto, e adesso l'undefined symbol ce l'ho per altra roba..ora.. il file cpp è wrapper per solo un .o che è contenuto un libtesseract_main.a, il quale ovviamente utilizza gli altri .o e altre librerie statiche.....magari provo ad aggiungerli tutti dopo con ld?...
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2007, 13:59   #13
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da cisc Guarda i messaggi
innanzitutto grazie mille! ho fatto come hai detto, e adesso l'undefined symbol ce l'ho per altra roba..ora.. il file cpp è wrapper per solo un .o che è contenuto un libtesseract_main.a, il quale ovviamente utilizza gli altri .o e altre librerie statiche.....magari provo ad aggiungerli tutti dopo con ld?...
Sì certo. Fai in modo che il tuo .so abbia tutte le dipendenze che gli servono per essere caricato. Ricordati che se devi linkare gli .a l'ordine è importante: prima quelli che usano i successivi.
Sarà tutto ok quando riuscirai a fare un bel
LD_PRELOAD=<tuo so> cat /proc/self/maps
senza ottenere errori, e potendo vedere la tua libreria nell'elenco stampato.
__________________
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

Ultima modifica di ilsensine : 17-05-2007 alle 14:02.
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 20-05-2007, 12:36   #14
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
ok, grazie a tutti, sono riuscito a richiamare sta cavolo di libreria da java, anche se, ilsensine, facendo un bel LD_PRELOAD=<tuo so> cat /proc/self/maps mi da cmq errore..ma tanto chis se ne frega, riesco a richiamarla in java...
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2007, 12:30   #15
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
ragazzi, dovrei realizzare una dll in modo da far funzionare il mio codice anche su win, considerando che la lib che sto usando supporta anche win, anzi, nell'ultima versione hanno prodotto loro stessi una dll...solo che ho esperienza zero su win...

nel readme c'è scritto questo:
Quote:
=== Windows users only ===
Added a dll interface for windows. Thanks to Glen at Jetsoft for contributing
this. To use the dll, include tessdll.h, import tessdll.lib and put tessdll.dll
somewhere where the system can find it. There is also a small dlltest program
to test the dll. Run with:
dlltest phototest.tif phototest.txt
It will output the text from phototest.tif with bounding box information.
**New for Windows** the distribution now includes tesseract.exe and tessdll.dll
which *might* work out of the box! There are no guarantees as you need
VC++6 versions of mfc and crt (at least) for it to work. (Batteries not
included, and certainly no installshield.)
che significa che devo importare tessdll.lib? posso eventualmente seguire lo stesso procedimento usato per linux utilizzando cygwin? grazie mille
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2007, 12:49   #16
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Puoi usare cygwin, a patto di usare gcc con l'opzione mingw. Oppure puoi installare msys+mingw. Non dovrebbe esserci bisogno del .lib; meglio ancora se compili tessdll con mingw.

Nota che ora dovresti veramente risolvere questo:
Quote:
anche se, ilsensine, facendo un bel LD_PRELOAD=<tuo so> cat /proc/self/maps mi da cmq errore..ma tanto chis se ne frega, riesco a richiamarla in java
in quanto, a differenza dei .so, non puoi generare una dll con simboli non risolti.
__________________
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
Old 24-05-2007, 18:42   #17
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
grazie ancora, ma c'è un modo per capire per quale motivo da errore il preload della libreria?
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2007, 09:45   #18
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Dovrebbe stamparti sulla console il motivo, ad es. quale è il simbolo non risolto.
__________________
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
Old 25-05-2007, 12:46   #19
cisc
Senior Member
 
L'Avatar di cisc
 
Iscritto dal: Nov 2002
Città: Cosenza --> Roma
Messaggi: 853
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Dovrebbe stamparti sulla console il motivo, ad es. quale è il simbolo non risolto.
strano, a me da solo un errore generico:|....adesso non sono dal mio pc, più tardi appena posso posto l'errore che mi da...
__________________
GNU MyServer Wants YOU!!
We live thinking we will never die. We die thinking we had never lived. Jason Becker
cisc è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2007, 13:34   #20
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Poco male, quando farai la dll vedrai tutti gli errori di linking. Probabilmente devi linkare qualche libreria java.
__________________
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


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Xbox Cloud Gaming arriva su Amazon Fire ...
Un blackout a San Francisco manda in til...
Windows 11 è diventato più...
Apple cambia strategia a causa della cri...
007 First Light: uscita rimandata di due...
Samsung Galaxy A37 e A57: il comparto fo...
DAZN lancia la sua offerta di Natale: My...
Gigabyte fa marcia indietro? Sparito il ...
Alcuni rivenditori giapponesi bloccano l...
Le feste non placano Amazon, anzi: aggio...
Roborock Q10 S5+ a un super prezzo: robo...
Formula sceglie WINDTRE BUSINESS per gar...
EXPO 1.20: AMD migliora il supporto all'...
MacBook Pro con chip M4, 24GB di RAM e 1...
Lefant M330 da 6.000Pa a 139€ o ECOVACS ...
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: 21:34.


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