Differenze tra le versioni di "Exit () - exit ()"
(6 versioni intermedie di uno stesso utente non sono mostrate) | |||
Riga 1: | Riga 1: | ||
− | =Uso della funzione | + | =Uso della funzione "exit()"= |
− | La funzione | + | La funzione, dichiarata nel file header "''/usr/include/stdlib.h''": |
void exit(int status) | void exit(int status) | ||
− | + | termina il programma. I buffer dei file vengono svuotati, i flussi sono chiusi, ed i file temporanei vengono eliminati. In sostanza la funzione esterna "exit()" termina l'intero processo, senza tenere in debita considerazione dei rilasci di risorse (deallocazione di memoria, chiusura di connessioni internet, etc.). Dovrebbe essere usato solo per particolarissimi casi di necessità, come ad esempio per ''out of memory'', per spazio disco terminato o per gravi errori hardware. | |
− | Volendola utilizzare in Gambas, bisognerà dichiararla con Extern, nonché dichiarare la libreria di C: libc.so.6, nella quale la funzione è contenuta. Da sottolineare che, poiché questa funzione esterna di C " | + | Volendola utilizzare in Gambas, bisognerà dichiararla con Extern, nonché dichiarare la libreria di C: libc.so.6, nella quale la funzione è contenuta. Da sottolineare che, poiché questa funzione esterna di C "exit()" è <SPAN style="text-decoration:underline">omonima</span> alla funzione di Gambas "Exit", bisognerà assegnarle un nome a piacere, ma si dovrà anche richiamare il suo vero nome con il comando ''Exec''. |
<BR>Il parametro della funzione sarà posto a zero. | <BR>Il parametro della funzione sarà posto a zero. | ||
<BR>Dunque avremo ad esempio: | <BR>Dunque avremo ad esempio: | ||
Private <FONT color=#B22222>Extern exit_C</font>(status As Integer) In "<FONT color=#B22222>libc:6"</font> <FONT color=#B22222>'''Exec "exit"'''</font> | Private <FONT color=#B22222>Extern exit_C</font>(status As Integer) In "<FONT color=#B22222>libc:6"</font> <FONT color=#B22222>'''Exec "exit"'''</font> | ||
− | |||
− | |||
Semplice esempio di uso in Gambas: | Semplice esempio di uso in Gambas: | ||
Riga 17: | Riga 15: | ||
− | + | Public Sub Main() | |
Dim i As Integer | Dim i As Integer | ||
− | + | Do | |
− | + | Print i | |
<FONT color=Gray>' ''Giunta la variabile "i" a 1000, la funzione esterna "exit_C", ossia "exit()", chiude il programma:''</font> | <FONT color=Gray>' ''Giunta la variabile "i" a 1000, la funzione esterna "exit_C", ossia "exit()", chiude il programma:''</font> | ||
− | + | If i == 1000 Then <FONT color=#B22222>exit_C(0)</font> | |
− | + | Inc i | |
− | + | Loop | |
− | + | End | |
− | |||
− | |||
===Ottenere il medesimo effetto della funzione ''exit()'' con l'Assembly=== | ===Ottenere il medesimo effetto della funzione ''exit()'' con l'Assembly=== | ||
Per ottenere l'uscita dal programma, potremmo utilizzare l'Assembly chiamando la ''syscall'' corrispondente alla funzione 1 dell'interrupt 0x80. | Per ottenere l'uscita dal programma, potremmo utilizzare l'Assembly chiamando la ''syscall'' corrispondente alla funzione 1 dell'interrupt 0x80. | ||
− | |||
In questo esempio creeremo un'apposita libreria esterna scritta in C, nella quale sarà inserito ''inline'' il necessario codice in linguaggio Assembly: | In questo esempio creeremo un'apposita libreria esterna scritta in C, nella quale sarà inserito ''inline'' il necessario codice in linguaggio Assembly: | ||
Riga 43: | Riga 38: | ||
− | + | Public Sub Main() | |
Dim i As Integer | Dim i As Integer | ||
− | + | Creaso() | |
− | + | Do | |
− | + | Inc i | |
− | + | If i == 10000 Then asm_C(0) | |
− | + | Wait 0.001 | |
− | + | Print i | |
− | + | Loop | |
− | + | End | |
− | + | Private Procedure Creaso() | |
+ | |||
+ | File.Save("/tmp/Casm.c", "void asm_C(int b) {\n" & | ||
+ | " int a;\n\n" & | ||
+ | " __asm__(\"mov $1, %%eax;\"\n" & | ||
+ | " \"mov $0,%%ebx;\"\n" & | ||
+ | " \"int $0x80;\"\n" & | ||
+ | " : \"=a\" (a)\n" & | ||
+ | " : \"b\" (b)\n);\n\n}") | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
Shell "gcc -o /tmp/Casm.so /tmp/Casm.c -shared" Wait | Shell "gcc -o /tmp/Casm.so /tmp/Casm.c -shared" Wait | ||
− | + | ||
− | + | End | |
− | |||
− | =Uso della funzione | + | =Uso della funzione "_exit()"= |
− | La funzione | + | La funzione, dichiarata nel file header ''/usr/include/unistd.h'': |
void _exit (int __status) | void _exit (int __status) | ||
− | + | rispetto alla funzione "exit()" non chiama la funzione "fflush()" per lo svuotamento dei buffer associati all'I/O bufferizzato. | |
− | |||
− | |||
− | |||
Volendola utilizzare in Gambas, bisognerà dichiararla con Extern, nonché dichiarare la libreria di C: libc.so.6, nella quale la funzione è contenuta. | Volendola utilizzare in Gambas, bisognerà dichiararla con Extern, nonché dichiarare la libreria di C: libc.so.6, nella quale la funzione è contenuta. | ||
− | + | Dunque avremo ad esempio: | |
Private <FONT color=#B22222>Extern _exit</font>(__status As Integer) In "<FONT color=#B22222>libc:6"</font> | Private <FONT color=#B22222>Extern _exit</font>(__status As Integer) In "<FONT color=#B22222>libc:6"</font> | ||
− | |||
Semplice esempio di uso in Gambas: | Semplice esempio di uso in Gambas: | ||
Riga 96: | Riga 85: | ||
− | + | Public Sub Main() | |
Dim i As Integer | Dim i As Integer | ||
− | + | Do | |
− | + | Print i | |
<FONT color=Gray>' ''Giunta la variabile "i" a 1000, la funzione esterna "_exit" chiude il programma:''</font> | <FONT color=Gray>' ''Giunta la variabile "i" a 1000, la funzione esterna "_exit" chiude il programma:''</font> | ||
− | + | If i == 1000 Then <FONT color=#B22222>_exit(0)</font> | |
− | + | Inc i | |
− | + | Loop | |
− | + | End | |
− | + | Si dovrebbe usare la funzione "_exit()" per interrompere il programma ''Figlio'', quando la funzione ''exec'' fallisce, perché in questa situazione, il processo ''Figlio'' può interferire con i dati esterni (file) del processo ''Padre''. | |
− | + | <BR>Per lo stesso motivo, si dovrebbe anche usare "_exit()" in qualsiasi processo figlio che non fa un exec, ma quelli sono rari. | |
− | Si dovrebbe usare la funzione | ||
− | <BR>Per lo stesso motivo, si dovrebbe anche usare | ||
− | |||
− | |||
+ | In tutti gli altri casi, basta usare la funzione "exit()". | ||
Versione attuale delle 10:44, 13 giu 2024
Indice
Uso della funzione "exit()"
La funzione, dichiarata nel file header "/usr/include/stdlib.h":
void exit(int status)
termina il programma. I buffer dei file vengono svuotati, i flussi sono chiusi, ed i file temporanei vengono eliminati. In sostanza la funzione esterna "exit()" termina l'intero processo, senza tenere in debita considerazione dei rilasci di risorse (deallocazione di memoria, chiusura di connessioni internet, etc.). Dovrebbe essere usato solo per particolarissimi casi di necessità, come ad esempio per out of memory, per spazio disco terminato o per gravi errori hardware.
Volendola utilizzare in Gambas, bisognerà dichiararla con Extern, nonché dichiarare la libreria di C: libc.so.6, nella quale la funzione è contenuta. Da sottolineare che, poiché questa funzione esterna di C "exit()" è omonima alla funzione di Gambas "Exit", bisognerà assegnarle un nome a piacere, ma si dovrà anche richiamare il suo vero nome con il comando Exec.
Il parametro della funzione sarà posto a zero.
Dunque avremo ad esempio:
Private Extern exit_C(status As Integer) In "libc:6" Exec "exit"
Semplice esempio di uso in Gambas:
' void exit(int status) ' Terminates the calling process immediately. Any open file descriptors belonging to the process are closed. Private Extern exit_C(status As Integer) In "libc:6" Exec "exit" Public Sub Main() Dim i As Integer Do Print i ' Giunta la variabile "i" a 1000, la funzione esterna "exit_C", ossia "exit()", chiude il programma: If i == 1000 Then exit_C(0) Inc i Loop End
Ottenere il medesimo effetto della funzione exit() con l'Assembly
Per ottenere l'uscita dal programma, potremmo utilizzare l'Assembly chiamando la syscall corrispondente alla funzione 1 dell'interrupt 0x80.
In questo esempio creeremo un'apposita libreria esterna scritta in C, nella quale sarà inserito inline il necessario codice in linguaggio Assembly:
' void asm_C(int i) ' Termina un programma liberando tutta la memoria impegnata per esso. Private Extern asm_C(b As Integer) In "/tmp/Casm" Public Sub Main() Dim i As Integer Creaso() Do Inc i If i == 10000 Then asm_C(0) Wait 0.001 Print i Loop End Private Procedure Creaso() File.Save("/tmp/Casm.c", "void asm_C(int b) {\n" & " int a;\n\n" & " __asm__(\"mov $1, %%eax;\"\n" & " \"mov $0,%%ebx;\"\n" & " \"int $0x80;\"\n" & " : \"=a\" (a)\n" & " : \"b\" (b)\n);\n\n}") Shell "gcc -o /tmp/Casm.so /tmp/Casm.c -shared" Wait End
Uso della funzione "_exit()"
La funzione, dichiarata nel file header /usr/include/unistd.h:
void _exit (int __status)
rispetto alla funzione "exit()" non chiama la funzione "fflush()" per lo svuotamento dei buffer associati all'I/O bufferizzato.
Volendola utilizzare in Gambas, bisognerà dichiararla con Extern, nonché dichiarare la libreria di C: libc.so.6, nella quale la funzione è contenuta.
Dunque avremo ad esempio:
Private Extern _exit(__status As Integer) In "libc:6"
Semplice esempio di uso in Gambas:
' void _exit(int __status) ' Terminate program execution with the low-order 8 bits of STATUS. Private Extern _exit(__status As Integer) In "libc:6" Public Sub Main() Dim i As Integer Do Print i ' Giunta la variabile "i" a 1000, la funzione esterna "_exit" chiude il programma: If i == 1000 Then _exit(0) Inc i Loop End
Si dovrebbe usare la funzione "_exit()" per interrompere il programma Figlio, quando la funzione exec fallisce, perché in questa situazione, il processo Figlio può interferire con i dati esterni (file) del processo Padre.
Per lo stesso motivo, si dovrebbe anche usare "_exit()" in qualsiasi processo figlio che non fa un exec, ma quelli sono rari.
In tutti gli altri casi, basta usare la funzione "exit()".
Riferimenti
- https://linux.die.net/man/3/exit
- https://linux.die.net/man/3/_exit
- http://man7.org/linux/man-pages/man2/_exit.2.html
- http://www.science.unitn.it/~fiorella/guidac/guidac098.html
- http://digilander.libero.it/uzappi/C/librerie/funzioni/exit.html
- http://digilander.libero.it/uzappi/C/librerie/funzioni/_exit.html