|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Member
Iscritto dal: Aug 2012
Messaggi: 268
|
[C]oggi ,scrivere codice riusabile
Ciao ho una domanda-sondaggio:quanti cercano di usare il C come se fosse un linguaggioad oggetti?quanti lo ritengono sensato?quanti hanno mai usati gli Adt come se fossero oggetti?aggiungo :quale approccio usate per scrivere codice riusabile in C?
|
|
|
|
|
|
#2 | ||
|
Senior Member
Iscritto dal: Aug 2003
Città: Barletta (BA)
Messaggi: 939
|
Non è raro vedere codice C che prende svariate idea dall'OOP, dai uno sguardo a Gtk
Quote:
Quote:
__________________
In a world without fences, who needs Gates? Power by: Fedora 8 - Mac OS X 10.4.11 |
||
|
|
|
|
|
#3 |
|
Member
Iscritto dal: Aug 2012
Messaggi: 268
|
rimaniamo in topic e in C : quali tecniche usate per scrivere codice riusabile?
il discorso Adt nasce dando un occhiata a questo libro http://www.amazon.com/Interfaces-Imp.../dp/0201498413 il C non è un linguaggio ad oggetti: perchè volerlo usare come tale? |
|
|
|
|
|
#4 | |
|
Senior Member
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
|
Quote:
Mi riferisco soprattutto a sistemi a microprocessore in cui il costo della cpu puo' incidere fortemente sul costo dell'intero sistema. Ho lavorato con processori a 4 bit (e memoria totale 1 Kb) appunto per questo motivo. Era stata implementata un'architettura con un nome particolare (che ovviamente non posso riportare sul forum) ma che si poteva tradurre come "architettura ad oggetti magri" Esistono anche sistemi di automazione per grandi impianti ad alta capacita' produttiva, dove il fermo impianto costa un capitale. Si tratta di impianti che non si fermano mai (o magari fanno un fermo all'anno) e l'automazione viene rinnovata "a pezzi". Non e' infrequente che i produttori debbano garantire software e parti di ricambio per almeno 20 anni. Trovi il software in C (spesso C K&R, nemmeno ANSI) anche li. Il C e' spesso visto come un assembly strutturato, quindi piu' facile da capire/modificare/... dell'assembly stesso, e piu' portabile fra i vari processori supportati. In piu' e' facile costruire un compilatore, almeno per le istruzioni base.
__________________
In God we trust; all others bring data Ultima modifica di sottovento : 28-05-2014 alle 22:19. |
|
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
|
Quote:
__________________
In God we trust; all others bring data |
|
|
|
|
|
|
#6 |
|
Member
Iscritto dal: Aug 2012
Messaggi: 268
|
..ma quali tecniche usate per scrivere codice riusabile e facilmente mantenibile in C?
per tornare in topic |
|
|
|
|
|
#7 | |
|
Senior Member
Iscritto dal: May 2001
Messaggi: 12862
|
Quote:
Il punto è, devi scrivere una libreria? Una libreria per gestire cosa? Parte SEMPRE tutto dal problema che devi risolvere. In generale comunque ritengo che concentrarsi subito sull'interfaccia (API) sia in assoluto una delle prime cose da fare. Inoltre darsi anche delle regole di stile sensate e che vengano mantenute per tutto il progetto (ad esempio, cosa ritornano tutte le funzioni, come vengono gestiti input ed output, si usano nomi minuscoli per i tipi e nomi che iniziano con una lettera maiuscola per le variabili, si usa un prefisso per le variabili di tipo puntatore, tipo pStudente, e cose così...). Il C ha il vantaggio rispetto a C++ di essere un linguaggio mediamente più facile da comprendere, MA ha anche degli aspetti tediosi, tra cui sicuramente la gestione degli errori e delle risorse (allocazione/deallocazione), che ritengo cruciali in un qualsiasi progetto. Da questo punto di vista ad esempio la possibilità di creare classi in un qualsiasi linguaggio ad oggetti è ottimo perché ti evita all'interno della classe stessa di fare controlli "inutili" dal momento che puoi in qualsiasi momento stabilire una invariante di classe, e questo di fatto ti evita di riempire il codice di (if ... != NULL) e cose varie che rompono il flusso e riducono la leggibilità. Fare la stessa cosa in C richiede più sforzo e molta disciplina da parte del programmatore. Comunque si cerca di mimare un po' il concetto di eccezione anche in C usando i costrutti goto per evitare di duplicare il codice di gestione di un errore. Se ti è mai capitato di dare un'occhiata al codice del kernel Linux (scritto in C) gli errori sono gestiti in quel modo Ultima modifica di WarDuck : 30-05-2014 alle 10:57. |
|
|
|
|
|
|
#8 |
|
Member
Iscritto dal: Aug 2012
Messaggi: 268
|
ciao mi chiedevo se in C esistesse qualcosa di analogo ai principi SOLID della programmazione ad oggetti. ho citato il libro http://www.amazon.com/Interfaces-Imp.../dp/0201498413
proprio per qusto motivo.vorrei sapere se voi usate quelle tecniche : adt e interfacce |
|
|
|
|
|
#9 |
|
Member
Iscritto dal: Dec 2013
Messaggi: 90
|
L' adt è una tecnica per rendere una struttura privata.
In questo modo solo chi ha creato l'adt può accedere direttamente alle proprietà della struttura. Questo centra ben poco a livello di riutilizzo del codice, è piu che altro una tecnica di programmazione difensiva. Utilizzare poi realmente un c ad oggetti è una tecnica alquanto complessa e inutile. Il poter riutilizzare codice si deve basare quindi su di un codice che possa essere implementato facilmente in ogni occasione.Durante il mio studio del c mi sono ricreato un set di librerie che contengono moltissime funzioni riutilizzabili sia basate su adt che non. Bisogna quindi imparare a scrivere funzioni "slegate" dal programma principale, in modo tale da poter essere inserite in una libreria ed riutilizzate tutte le volte che si vuole. |
|
|
|
|
|
#10 | |
|
Senior Member
Iscritto dal: Oct 2005
Messaggi: 1056
|
Quote:
non ho resistito |
|
|
|
|
|
|
#11 |
|
Member
Iscritto dal: Dec 2013
Messaggi: 90
|
per essere pignoli per mimare le eccezioni si usa la setjmp e non la goto!
La goto a mio avviso rimane una tecnica tanto brutta quanto funzinale. |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 21:23.




















