Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-10-2003, 21:55   #1
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
[C] E' possibile in una funzione....

Ciao .

Mi chiedevo , se inquesto programmino che ho fatto per risolvere il classico problema delle torri di Hanoi :

Codice:
#include <stdio.h>
#include <stdlib.h>
                                                                                                                                                            
int hanoi(int, int, int, int);
                                                                                                                                                            
main()
{
        int disks;
        int pal1,pal2,pal3;
        printf("Indica il numero dei dischi: ");
        scanf("%d", &disks);
        printf("Indica il paletto iniziale: ");
        scanf("%d", &pal1);
        printf("Indica il paletto temporaneo: ");
        scanf("%d", &pal2);
        printf("Indica il paletto finale: ");
        scanf("%d", &pal3);
        hanoi(disks, pal1, pal2, pal3);
        return 0;
}
                                                                                                                                                            
int hanoi(int dischi, int a, int b, int c)
{
        if(dischi == 1){
           printf("%d --> %d\n", a, c);
           return 0;
        }
        hanoi(dischi - 1, a, c, b);
        printf("%d --> %d\n", a, c);
        hanoi(dischi - 1, b, a, c);
        return 0;
}
Fosse proprio necessario imporre alla funzione hanoi il tipo "int" per fagli returnare il valore "0" (o "1") per fargli terminare l'esecuzione della funzione in un dato punto.

Mi spiego meglio :

Inizialmente avevo scritto il programma con la funzione "hanoi" come tipo "void" , solo che effettivamente non avevo messo niente all' interno del blocco IF che facesse bloccare la ricorsione ,e il programma andava in "segmentation fault" (e pensare che me ne sono accorto solo grazie a "GDB" quando mi segnava che il valore di dischi nella funzione "hanoi" era di "-254353", che falco che sono , vero? ). Così ho usato questo metodo di astuzia e ho impostato le funzioni come INT per poi fargli returnare un valore che facesse terminare l'esecuzione della funzione stessa .

Ora, io mi chiedevo se ci fosse un metodo per fare in modo che la funzione venga terminata senza avvalersi dell' uso della parola chiave "return" (ad esempio impostando la funzione come tipo "void" e poi terminare l'esecuzione in qualche modo ) .

Vorrei che sia chiaro il fatto che mi interessano solo metodi appartenenti alla programmazione Strutturata , quindi niente "break" , "continue", salti incondizionati et simila .

Non è niente che mi serva personalmente , ma è solo una curiosità

Grazie

Ciao
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 11-10-2003, 22:27   #2
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
non capito perchè non vuoi usare return;
in ogni caso prova ad invertire la logica dei controlli.

ciao
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 11-10-2003, 22:37   #3
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
Quote:
Originariamente inviato da VICIUS
non capito perchè non vuoi usare return;
in ogni caso prova ad invertire la logica dei controlli.

ciao

non è che non voglio usare return è che inizialmente avevo settato HANOI come "void" e poi per fargli usare return gli ho dovuto cambiare il valore da "void" a "int" , mi chiedevo se tenendo tenendo la funzione "void" ci fosse un modo per terminare la funzione nel caso appunto "Dischi fosse 1" .

In che senso invertire la logica dei controlli?

Ciao
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 11-10-2003, 22:41   #4
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
qualcosa tipo questo:
Codice:
void
hanoi (int dischi, int a, int b, int c)
{
  if (dischi > 1) 
    {
      hanoi ((dischi - 1), a, c, b);
      printf ("%d --> %d\n", a, c);
      
      hanoi ((dischi - 1), b, a, c);
    }
  
  printf("%d --> %d\n", a, c);
}
nel tuo programma controlli quando deve terminare. mentre qui controlla quando deve continuare.

ciao
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 11-10-2003, 22:47   #5
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
Quote:
Originariamente inviato da VICIUS
qualcosa tipo questo:
Codice:
void
hanoi (int dischi, int a, int b, int c)
{
  if (dischi > 1) 
    {
      hanoi ((dischi - 1), a, c, b);
      printf ("%d --> %d\n", a, c);
      
      hanoi ((dischi - 1), b, a, c);
    }
  
  printf("%d --> %d\n", a, c);
}
nel tuo programma controlli quando deve terminare. mentre qui controlla quando deve continuare.

ciao




Astuto



Grazie VICIUS
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2003, 09:55   #6
mjordan
Bannato
 
L'Avatar di mjordan
 
Iscritto dal: Mar 2002
Città: Pescara - 未婚・恋人なし Moto: Honda CBR 1000 RR ‫Casco: XR1000 Diabolic 3
Messaggi: 27578
Comunque una funzione di tipo void non deve necessariamente ritornare un valore per uscire. Basta usare l'istruzione return liscia senza ritornare alcun valore.

Codice:
return;
mjordan è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2003, 10:00   #7
mjordan
Bannato
 
L'Avatar di mjordan
 
Iscritto dal: Mar 2002
Città: Pescara - 未婚・恋人なし Moto: Honda CBR 1000 RR ‫Casco: XR1000 Diabolic 3
Messaggi: 27578
In sostanza non serve modificare la logica della funzione, basta usare correttamente le istruzioni return:

Codice:
void
hanoi(int dischi, int a, int b, int c)
{
        if(dischi) {
                printf("%d --> %d\n", a, c);
                return;
        }

        hanoi(dischi - 1, a, c, b);
        printf("%d --> %d\n", a, c);
        hanoi(dischi - 1, b, a, c);

        return;
}
anche se come ha scritto Vicius è sicuramente un modo molto piu' pulito di procedere. In genere non si dovrebbe mai aprire un blocco di un if() solo per includere un'istruzione con relativa return.
mjordan è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
Apple MacBook Neo 13'' con chip A18 Pro ...
Insieme a Leica SL3-P presentate le otti...
La Cina svilupperà anche il razzo...
Rocket Lab e la missione Victus Haze per...
Starship: Ship 40 ha eseguito uno static...
I nuovi Samsung Galaxy Watch 9 si mostra...
Einsten aveva ragione, di nuovo: captate...
Top 10 offerte Amazon: 5 sono partite qu...
AI Conf 2026: l'intelligenza artificiale...
Samsung Galaxy S26 scende a 711,49€: un ...
Dopo il maxi blackout, la Spagna cambia ...
Costa meno di un MacBook e fa molto di p...
Ecco tutti i robot aspirapolvere rimasti...
Più partite da seguire in contemporanea?...
389€ sono veramente pochi per questo PC ...
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:40.


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