Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Amazon porta i colori sul suo Kindle da scrittura più grande: schermo Colorsoft a 11 pollici, processore quad-core, penna premium più reattiva e strumenti IA per le note, sono le note salienti. Il salto di prezzo rispetto al modello in bianco e nero si fa sentire, anche se la percezione è quella di trovarsi di fronte a un prodotto di fascia altissima, per veri appassionati
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-01-2010, 11:33   #1
GByTe87
Senior Member
 
L'Avatar di GByTe87
 
Iscritto dal: Mar 2007
Città: Milano Beach
Messaggi: 1696
[C] Valutazione condizioni

Buongiorno a tutti

Avrei un quesito: le istruzioni che io utilizzo come condizioni, per esempio per un if, vengono eseguite sempre tutte?

Temo di essere stato criptico: ho un codice del genere:

Codice:
if ((struct_1.index > -1) && (struct_2[struct_1.index].description != NULL)) {
    doSomething();
}
Mettiamo, per esempio, che struct_1.index valga -1: la seconda parte della condizione (con relativo uso di un indice negativo per accedere a un array e conseguente sigsegv ) viene valutata?

Se può servire, compilo con GCC
Grazie
__________________
~ Cthulhu: MacBookPro 13.3" ~ Azathoth: D510MO
GByTe87 è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 11:37   #2
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7110
No, nel caso in esempio, essendoci un AND, se la prima condizione è falsa lo è anche l'AND, quindi la seconda non viene eseguita.

Non ricordo però se questo vale sempre o solo quando compili con ottimizzazioni

Con un OR è diverso, devono essere valutate per forza di cose entrambe, con o senza ottimizzazioni. Quindi dipende sia dalla tabella di verità dell'operatore sia dalle ottimizzazioni

Ultima modifica di Unrue : 22-01-2010 alle 17:44.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 11:42   #3
GByTe87
Senior Member
 
L'Avatar di GByTe87
 
Iscritto dal: Mar 2007
Città: Milano Beach
Messaggi: 1696
Quote:
Originariamente inviato da Unrue Guarda i messaggi
No, nel caso in esempio, essendoci un AND, se la prima condizione è falsa lo è anche l'AND, quindi la seconda non viene eseguita.
Mmm, perfetto, immaginavo fosse così

Grazie per la risposta rapida

Edit: infatti, ora vorrei capire se dipende dalle opzioni di ottimizzazione del compilatore... non vorrei avere un codice che si comporta in modo diverso in debug e in produzione... almeno, non più del solito
__________________
~ Cthulhu: MacBookPro 13.3" ~ Azathoth: D510MO
GByTe87 è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 11:46   #4
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7110
Quote:
Originariamente inviato da GByTe87 Guarda i messaggi
Mmm, perfetto, immaginavo fosse così

Grazie per la risposta rapida

Edit: infatti, ora vorrei capire se dipende dalle opzioni di ottimizzazione del compilatore... non vorrei avere un codice che si comporta in modo diverso in debug e in produzione... almeno, non più del solito
Ripensandoci, secondo me dipende dalle ottimizzazioni. Se gli dici di non farle con -O0, non deve ottimizzare 'if, quindi fa il check su entrambe le condizioni. Anche perché, in modalità debug, supponi che ci sia un errore nella seconda condizione, se la salta non rilevo l'errore..
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 12:45   #5
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2791
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Con un OR è diverso, devono essere valutate per forza di cose entrambe, con o senza ottimizzazioni. Quindi dipende sia dalla tabella di verità dell'operatore sia dalle ottimizzazioni
Mi sembra che con OR se la prima espressione è vera la seconda non viene valutata.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 12:50   #6
GByTe87
Senior Member
 
L'Avatar di GByTe87
 
Iscritto dal: Mar 2007
Città: Milano Beach
Messaggi: 1696
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Mi sembra che con OR se la prima espressione è vera la seconda non viene valutata.
In effetti sarebbe anche logico, in questo caso
__________________
~ Cthulhu: MacBookPro 13.3" ~ Azathoth: D510MO
GByTe87 è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 13:47   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Che io sappia nel linguagio C gli operatori logici booleani && e || sono "corto-circuitati" sempre, nel senso che sono tali proprio a livello semantico, quindi le opzioni di ottimizzazione del compilatore non c'entrano: ma magari mi ricordo male, qualcuno può confermare?
__________________

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 22-01-2010, 14:04   #8
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Mi sembra che con OR se la prima espressione è vera la seconda non viene valutata.
esatto, si chiama lazy OR e fa parte della specifica del linguaggio. esiste anche il lazy AND: se il primo operando dell'operatore && risulta nullo il secondo non viene valutato e l'espressione restituisce direttamente un valore nullo.
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 17:47   #9
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7110
Quote:
Originariamente inviato da fero86 Guarda i messaggi
esatto, si chiama lazy OR e fa parte della specifica del linguaggio. esiste anche il lazy AND: se il primo operando dell'operatore && risulta nullo il secondo non viene valutato e l'espressione restituisce direttamente un valore nullo.
Questa non la sapevo, si impara sempre qualcosa

Però secondo me in fase di debug non viene fatta, altrimenti per l'esempio postato prima, se nella seconda condizione ho un errore interno, lo salterei in quanto non viene valutata.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 17:54   #10
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 13005
Quote:
Originariamente inviato da Unrue Guarda i messaggi
No, nel caso in esempio, essendoci un AND, se la prima condizione è falsa lo è anche l'AND, quindi la seconda non viene eseguita.

Non ricordo però se questo vale sempre o solo quando compili con ottimizzazioni

Con un OR è diverso, devono essere valutate per forza di cose entrambe, con o senza ottimizzazioni. Quindi dipende sia dalla tabella di verità dell'operatore sia dalle ottimizzazioni
Con l'OR se la prima è verificata non c'è bisogno di vedere la seconda.

Con l'AND se la prima NON è verificata non c'è bisogno di vedere la seconda espressione.

Ovviamente sono arrivato in ritardo .

Ultima modifica di WarDuck : 22-01-2010 alle 17:56.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 18:11   #11
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 7110
Quote:
Originariamente inviato da WarDuck Guarda i messaggi
Con l'OR se la prima è verificata non c'è bisogno di vedere la seconda.
Si, infatti ho corretto
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2010, 22:43   #12
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Si, confermo che in C, C++ e anche C# la valutazione degli operando && e || e' lazy.
Utile quindi nei confronti con NULL per i puntatori

Quote:
if ((p!=null) && (p->campo!="valore"))
etc.
Il C, su tutti i compilatori, assicura che se la prima parte e' falsa, allora la seconda non viene neppure valutata. Che e' bene, altrimenti ci sarebbe un erroraccio a runtime

Questo e' quindi anche un ottimo motivo per non inserire codice "attivo" nelle valutazioni. Es se qualcuno scrive qualcosa come segue, spezziamo le braccine
Quote:
if ((a==-4) && (++c == 6) && (bs!="goofy"))
{
// qualcosa
}
Perche' e' facile che possa essere scappato che talvolta c viene incrementata, e talvolta no. Direi che quando la si legge invece che pensare ad una ottimizzazione (poco necessaria) e' molto piu' probabile un bel baco.

Da anche a maggior ragione bene a mente nei linguaggi come C# dove e' possibile scrivere del codice attivo anche in un semplice get di una proprieta',
la cui lettura parrebbe quindi innocente, ma che potrebbe dare problemi analoghi come il precedente.



E se invece scrivessi cosi', cosa accadrebbe?

Quote:
if ((struct_1.index > -1) & (struct_2[struct_1.index].description != NULL)) {
doSomething();
}
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 23-01-2010 alle 22:49.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2010, 00:11   #13
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
E se invece scrivessi cosi', cosa accadrebbe?
che le valuta entrambe perché l'AND é bitwise.
fero86 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
Rocket Lab acquisisce Iridium: nasce un ...
Una ventola nascosta e un design fuori d...
Display e fotocamera insieme: a Zurigo n...
Lenovo Idea Tab Plus, il tablet per stud...
Un ingegnere di AMD ha riprodotto in cas...
SanDisk Optimus cresce con nuovi SSD cer...
Loongson contro Intel e AMD: dalla Cina ...
Australia, quasi tutti gli under-16 aggi...
Oltre 1.300 miliardi di dollari per la p...
Un nuovo studio mette in dubbio la natur...
Crisi Volkswagen, torna l'ipotesi cessio...
Il CERN spegne il Large Hadron Collider:...
Stranger Than Heaven avrà una storia mol...
Il futuro prezzo di PS6 preoccupa i gioc...
AMD Ryzen 10000 sempre più vicini...
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: 22:13.


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