Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Nothing con il suo nuovo Phone 4(a) conferma la sua identità visiva puntando su una costruzione che nobilita il policarbonato. La trasparenza resta l'elemento cardine, arricchita da una simmetria interna curata nei minimi dettagli. Il sistema Glyph si evolve, riducendosi nelle dimensioni ma aumentando l'utilità quotidiana grazie a nuove funzioni software integrate e notifiche visive. Ecco tutti i dettagli nella recensione completa
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
DEEBOT T90 PRO OMNI abbina un sistema di aspirazione basato su tecnologia BLAST ad un rullo di lavaggio dei pavimenti dalla larghezza elevata, capace di trattare al meglio le superfici di casa minimizzando i tempi di lavoro. Un robot completo che riesce anche ad essere sottile e garantire automazione ed efficienza nelle operazioni di pulizia di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-06-2008, 12:30   #1
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Fractal Programming (considerazioni su DSL e Language Oriented Programming)

Posto il link ad un articolo interessante, vorrei sapere le vostre opinioni:

http://ola-bini.blogspot.com/2008/06...ogramming.html

Credo sia un approccio da valutare.
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 04-06-2008, 22:29   #2
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Il problema di un approccio come quello proposto secondo me non e' tanto la difficolta' del dover conoscere due (o piu'!) linguaggi diversi, ma dall'attrito che si genera tra uno "strato" e l'altro della piramide, dovute proprio alla diversita' che li caratterizzano. Quando dallo strato dinamico usi quello stabile ti trovi necessariamente a lavorare con un'API un po' aliena e molto probabilmente poco idiomatica, e c'e' poca alternativa ad una buona mole di lavoro manuale per ammorbidire le differenze. Questa quantita' di lavoro e' giustificata quando si producono binding per una libreria per uso pubblico, quando invece si e' fatto una scelta per lavorare meglio e in meno tempo e' gia' diverso. Bisogna trovare il "punto giusto" dove piazzare il salto tra uno strato e l'altro, (diciamo quanto piu' in basso e' ragionevole andare), ma non e' banale, e spesso neanche chiaro finche' si' e' iniziato il lavoro.
__________________
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 05-06-2008, 09:54   #3
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Quello che dici mi sembra sensato.
Non credo si possa definire una regola metodologica da usare sempre per definire dove fermarsi nell'interazione tra i vari livelli.

Per come la vedo io, il livello dinamico (quello centrale) dovrebbe fungere solo da "interprete" per i vari dsl ad alto livello, che nella mia personale visione sarebbero sempre linguaggi "interni", che non sono poi cosi difficili da implementare, e da, ovviamente, "aggancio" allo strato stabile (quello in basso).

Qui si genera l'attrito di cui parli, tutto vero, ma credo si tratti sempre di un problema di astrazione come ne affrontiamo tutti i giorni. Non credo sia un caso speciale. I videogiochi li fanno cosi da anni (c++/lua ad esempio...).

Io stavo pensando ad un approccio del genere per un web framework che sto pensando per il lavoro. Mi fanno tutti piuttosto schifo, e devo lavorare in un ambiente piuttosto "livellato" tra le varie applicazioni (java su websphere con la parte db a cura di stored procedure su oracle...la situazione è sempre questa. La maggior parte è solo CRUD, e raramente si sfora dagli schemi.).

Se un giorno mai avrò successo con questo approccio te lo farò sapere
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 05-06-2008, 12:08   #4
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Ho letto anche io l'articolo e l'ho trovato interessante.
Premesso che non sono un programmatore esperto, e le mie conoscenze sono ristrette solo ad alcuni ambiti limitati, la mia sensazione si identifica molto con l'opinione espressa da marco.r nel suo post.

Anche secondo me la sfida non sta tanto nel "diventare poliglotti" ma nel far lavorare in maniera flessibile i layer a contatto tra loro...

Questo per me significa trovare astrazioni comuni per definire un'interfaccia tra i vari layer, e il concetto mi ricorda molto cose come CORBA e COM; cioè una serie di standardizzazioni per creare l'infrastruttura neccessaria alla comunicazioni interprocesso.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 05-06-2008, 22:22   #5
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Concordo con marco.r. A lavoro utilizziamo diversi linguaggi e la coesistenza non è affatto facile. Tutt'altro.

Per fortuna ci stiamo muovendo verso la creazione di middleware con Ice alla base (è simile a CORBA, ma molto più semplice, flessibile ed efficiente), ma purtroppo al momento manca il binding per PERL (e l'unico collega che lo usa si amputerebbe le mani piuttosto che smettere e passare a... eresia! Python! ).

Quanto ai DSL, personalmente non mi piacciono: preferisco affidarmi a linguaggi già sviluppati e con una solida comunità alle spalle.

Comunque giusto oggi ho creato un DSL molto semplice (con ANTLR e generatore di parser in Python) per particolari esigenze che ho per un preciso progetto, ma si tratta di un evento raro, fortunatamente.

Certo, creare nuovi linguaggi mi affascina ed è da parecchi anni che mi cimento, ma dev'esserci uno scopo con un fondamento e il piatto della bilancia che penda inesorabilmente sul versante dei vantaggi.

Infatti per un'altra parte dello stesso progetto ho preferito non creare un DSL ad hoc, e affidarmi a Python: i vantaggi dell'avere un nuovo DSL erano decisamente inferiori.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2008, 09:25   #6
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
@cdimauro:
Certo, creare un linguaggio a sè stante (con parser e tutto quanto) anche con tool fighi come ANTLR (ci sto giocando un pò anch'io nei ritagli di tempo) può diventare molto dispendioso. Infatti non è la strada che percorrerei volendo usare vari DSL per risolvere problemi.

Quando si parla di DSL si parla di due tipologie: esterni (usando ANTLR o sarcazzo) e interni (modellando il linguaggio in modo che assomigli a qualcos'altro).

Io per esempio mi sono fatto, come esercizio un piccolo DSL che wrappa attorno a jdbc, in java:

Codice:
withConnection(JDBC_URI)
  .doThis(
    select("select * from emp where ename = ?")
      .in("Martin")
      .saveToList(empList, EmpBean.class));
Questo anche se non sembra, è java al 100%. Per me è un grosso passo avanti, perchè il corrispettivo codice "canonico" è mooolto più verboso ed è facile dimenticarsi di chiudere una connessione/statement/resultset/ecc...

E non è necessario molto impegno per scrivere una cosa del genere. Usando altri linguaggi, tipo ruby/groovy/lisp/... viene ancora più facile giocare sulla sintassi.
In lisp poi è l'approccio che si usa di solito, vedi On Lisp di Graham.

Poi i gusti sono gusti ovviamente Ma forse i tuoi gusti sono condizionati dal fatto che in python non è cosi facile modellare la sintassi per creare un DSL interno. Almeno, cosi dicono, io python lo conosco poco.
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 06-06-2008, 14:47   #7
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Quote:
Originariamente inviato da shinya Guarda i messaggi
@cdimauro:
Certo, creare un linguaggio a sè stante (con parser e tutto quanto) anche con tool fighi come ANTLR (ci sto giocando un pò anch'io nei ritagli di tempo) può diventare molto dispendioso. Infatti non è la strada che percorrerei volendo usare vari DSL per risolvere problemi.
Francamente non lo trovo complicato. Poi ovviamente dipende da ciò che bisogna farci: non è che realizzo compilatori, ma parser ed eventualmente qualche interprete per linguaggi semplici.
Quote:
Quando si parla di DSL si parla di due tipologie: esterni (usando ANTLR o sarcazzo) e interni (modellando il linguaggio in modo che assomigli a qualcos'altro).

Io per esempio mi sono fatto, come esercizio un piccolo DSL che wrappa attorno a jdbc, in java:

Codice:
withConnection(JDBC_URI)
  .doThis(
    select("select * from emp where ename = ?")
      .in("Martin")
      .saveToList(empList, EmpBean.class));
Questo anche se non sembra, è java al 100%. Per me è un grosso passo avanti, perchè il corrispettivo codice "canonico" è mooolto più verboso ed è facile dimenticarsi di chiudere una connessione/statement/resultset/ecc...

E non è necessario molto impegno per scrivere una cosa del genere. Usando altri linguaggi, tipo ruby/groovy/lisp/... viene ancora più facile giocare sulla sintassi.
In lisp poi è l'approccio che si usa di solito, vedi On Lisp di Graham.

Poi i gusti sono gusti ovviamente Ma forse i tuoi gusti sono condizionati dal fatto che in python non è cosi facile modellare la sintassi per creare un DSL interno. Almeno, cosi dicono, io python lo conosco poco.
Ho capito cosa intendi. I DSL interni al momento non li userei: è troppo facile estendere la sintassi con costrutti che magari servono poche volte, e rimane il problema di condividere queste estensioni con gli altri colleghi / utenti e la comunità.

Quanto a Python, è abbastanza facile giocare con la sintassi. Perché dici che con altri linguaggi è più facile realizzare DSL interni?
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
NVIDIA: raggiungeremo almeno 1 triliardo...
Lenovo presenta workstation e server con...
Nuova BMW i3: la Serie 3 elettrica debut...
NVIDIA torna in Cina: stretto un accordo...
Vibe coding nel mirino di Apple: ecco le...
Smart TV QLED 50'' a un super prezzo: 4K...
Horizon Worlds lascia i visori Quest: Me...
Lexar compie 30 anni e cambia le regole ...
Questo SSD fornisce memoria aggiuntiva a...
PlayStation Portal si aggiorna: arriva l...
Akamai, le API nel mirino dei cyber atta...
Spider-Man: Brand New Day, finalmente on...
La serie TV di Hitman è ufficialmente fe...
"Grazie e arrivederci": Sam Al...
Il CEO di Take-Two critica l'idea che l'...
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: 19:20.


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