Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-10-2004, 17:23   #1
Dreamwolf_81
Member
 
L'Avatar di Dreamwolf_81
 
Iscritto dal: Apr 2003
Messaggi: 265
Vita applicazioni Win32...C# o C++??

Ciao a tutti!

Devo intraprendere un nuovo progetto a lungo termine e creare un gestionale sotto windows (ma non disdegnerei linux in futuro) che fra l'altro acceda a risorse hardware come USB, RS232 e mi permetta una efficente programmazione dei socket.

Pultroppo in questi giorni sto impazzendo, non so decidermi se iniziare il progetto basandomi su C# della Microsoft oppure su C++ BuilderX della Borland. Entrambi hanno una cosa che l'altro non ha:

C# ->
PRO: Ottime prospettive di supporto e distribuzione per il futuro. Longhorn farà girare in maniera nativa le applicazioni .NET.
CONTRO: Non è portabile su alcuna altra piattaforma; per accedere all'ahardware ho comunque bisogno di codice (x es. DLL) unmanaged; Non gestisce i puntatori.

C++ BuilderX ->
PRO: Estendibile ad altre piattaforme, potenza dei puntatori in C; colloquio diretto con le API di windows, maggiore velocità e leggerezza del codice prodotto.
CONTRO: Sarà supportato in seguito da Borland?; Viste le prospettive di Longhorn, quanta vita rimarrà alle applicazioni Win32 se la Microsoft decide di spostarsi completamente su .NET?

Per concludere il post: Visto che questo mio progetto deve avere una durata minima di 6 anni e dovrà essere aggiornato continuamente voi che mi consiglereste? Come lo vedete il futuro di C# e C++?

Vi saluto e vi ringrazio anticipatamente.
__________________
He said: Quando hai un nemico non ucciderlo, siediti sulla sponda del fiume e aspetta che passi il suo cadavere...
Dreamwolf_81 è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2004, 17:30   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Se intendi accedere all'hw, non puoi avere troppe pretese di compatibilità cross/platform. Su una singola famiglia di sistemi operativi le prospettive sono migliori, in quanto si cerca di tenere la compatibilità in ambiente user space.
In ogni caso ti consiglio di usare un toolkit c++ multipiattaforma, per ridurre almeno alla sola gestione dell'hw le differenze tra diverse architetture.
__________________
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 01-10-2004, 17:31   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Imho C++ standard con un framework free come wxWidgets o FoxToolkit...
Per accedere all'hardware basta farti classi diverse per ogni SO...e metti tutto l'accesso all'hardware "nascosto" all'interno di una classe...

Ad esempio... Tutte le API di Windows per accedere, mettiamo, ad una porta seriale andranno all'interno della classe "serial_port"...

Ultima modifica di cionci : 01-10-2004 alle 17:33.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2004, 17:32   #4
Dreamwolf_81
Member
 
L'Avatar di Dreamwolf_81
 
Iscritto dal: Apr 2003
Messaggi: 265
Quote:
Originariamente inviato da ilsensine
Se intendi accedere all'hw, non puoi avere troppe pretese di compatibilità cross/platform. Su una singola famiglia di sistemi operativi le prospettive sono migliori, in quanto si cerca di tenere la compatibilità in ambiente user space.
In ogni caso ti consiglio di usare un toolkit c++ multipiattaforma, per ridurre almeno alla sola gestione dell'hw le differenze tra diverse architetture.
Per l'hardware avevo ipotizzato una compilazione condizionale...
__________________
He said: Quando hai un nemico non ucciderlo, siediti sulla sponda del fiume e aspetta che passi il suo cadavere...
Dreamwolf_81 è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2004, 17:36   #5
Dreamwolf_81
Member
 
L'Avatar di Dreamwolf_81
 
Iscritto dal: Apr 2003
Messaggi: 265
Quote:
Originariamente inviato da cionci
Imho C++ standard con un framework free come wxWidgets o FoxToolkit...
Per accedere all'hardware basta farti classi diverse per ogni SO...e metti tutto l'accesso all'hardware "nascosto" all'interno di una classe...

Ad esempio... Tutte le API di Windows per accedere, mettiamo, ad una porta seriale andranno all'interno della classe "serial_port"...
Osservazione + che giusta, ma non è questo il problema... la mia preoccupazione di fondo è il supporto delle applicazione Win32 API "pure" da Longhorn in poi.
__________________
He said: Quando hai un nemico non ucciderlo, siediti sulla sponda del fiume e aspetta che passi il suo cadavere...
Dreamwolf_81 è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2004, 17:50   #6
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
A quel punto, se l'architettura a classi l'hai fatta bene, basta solamente creare un'altra classe "serial_port" e gestirti praticamente un nuovo SO...

Comunque IMHO la compatibilità ci sarà ancora al 100%...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 02-10-2004, 02:12   #7
end.is.forever
Senior Member
 
Iscritto dal: Jul 2004
Messaggi: 1578
Longhorn emulerà alla perfezione tutte le Win32 API.

Per quanto riguarda i vantaggi nella scelta tra .NET e unmanaged ancora è difficile prevedere quando (e se, dato che il supporto nativo di .NET da parte di un os resta ancora una promessa e le API attuali forniscono solo una piccolissima percentuale di quello che permette Win32) avverrà.

In ogni caso ti consiglio C++ con una certa dose di accorgimenti per la portabilità e per eventuali cambiamenti di requisiti/API (per entrambe le cose è molto comodo usare un framework completo fatto da qualcun'altro ).
Ovviamente le differenze sono minime (sia per prestazioni che per tempi di sviluppo), il motivo per cui io preferirei C++ è che non vedendo vantaggi immediati dall'altra parte preferirei andare sul sicuro su qualcosa che già fornisce tutto quello che serve.

Un'altra cosa, se prendi molti accorgimenti anche un eventuale passaggio a C++ managed in futuro non dovrebbe essere particolarmente dispendioso.
end.is.forever è offline   Rispondi citando il messaggio o parte di esso
Old 02-10-2004, 12:27   #8
Dreamwolf_81
Member
 
L'Avatar di Dreamwolf_81
 
Iscritto dal: Apr 2003
Messaggi: 265
Quote:
Originariamente inviato da end.is.forever
Longhorn emulerà alla perfezione tutte le Win32 API.

Per quanto riguarda i vantaggi nella scelta tra .NET e unmanaged ancora è difficile prevedere quando (e se, dato che il supporto nativo di .NET da parte di un os resta ancora una promessa e le API attuali forniscono solo una piccolissima percentuale di quello che permette Win32) avverrà.

In ogni caso ti consiglio C++ con una certa dose di accorgimenti per la portabilità e per eventuali cambiamenti di requisiti/API (per entrambe le cose è molto comodo usare un framework completo fatto da qualcun'altro ).
Ovviamente le differenze sono minime (sia per prestazioni che per tempi di sviluppo), il motivo per cui io preferirei C++ è che non vedendo vantaggi immediati dall'altra parte preferirei andare sul sicuro su qualcosa che già fornisce tutto quello che serve.

Un'altra cosa, se prendi molti accorgimenti anche un eventuale passaggio a C++ managed in futuro non dovrebbe essere particolarmente dispendioso.
Già..., penso che sia la cosa più inteligente da fare. Sull'utilizzo di Borland BuilderX che ne pensate? Da come l'ho potuto provare io mi sembra più che valido. E un'integrazione con wxWindows mi sembra appunto l'ideale.
__________________
He said: Quando hai un nemico non ucciderlo, siediti sulla sponda del fiume e aspetta che passi il suo cadavere...
Dreamwolf_81 è offline   Rispondi citando il messaggio o parte di esso
Old 02-10-2004, 13:23   #9
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Programma direttamente sfruttando porting di GCC per Windows...ad esempio MinGW32 con un IDE come MinGW Developer Studio o Dev C++... Così non avrai sicuramente problemi nel porting...
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Forza Horizon 6: ulteriori dettagli emer...
Nuovi limiti ai biocarburanti: quelli a ...
HONOR Magic8 Pro: lo smartphone che vede...
Batterie allo stato solido anche da Geel...
Fable torna ad essere protagonista: annu...
Google integra i dati di Gmail e Foto de...
Curl ha chiuso il suo bug bounty: tutta ...
Ericsson 5G Advanced: geolocalizzazione ...
Elon Musk annuncia che Tesla, entro il 2...
Speciale robot aspirapolvere in offerta ...
Epic Games e Google: emerge una partners...
Apple ridisegna i vertici: John Ternus a...
A Santa Maria Maggiore le donazioni ora ...
Le 7 offerte migliori di Amazon oggi: 3 ...
Intel chiude il Q4 2025 sopra le attese:...
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: 11:55.


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