Differenze tra le versioni di "Scanf()"

Da Gambas-it.org - Wikipedia.
 
Riga 8: Riga 8:
 
  "%s" per ottenere una stringa (priva di spazi !);
 
  "%s" per ottenere una stringa (priva di spazi !);
 
  "%p" per ottenere un indirizzo di memoria.
 
  "%p" per ottenere un indirizzo di memoria.
La Direttiva di conversione "s" con ''scanf( )'' accetta una stringa di caratteri non comprendente gli spazi: quando viene incontrato uno spazio, la lettura dell'input si arresta. <SUP>&#91;[[#Note|Nota 1]]&#93;</sup>
+
La Direttiva di conversione "s" con ''scanf( )'' accetta una stringa di caratteri non comprendente gli spazi: quando viene incontrato uno spazio, la lettura dell'input si arresta. <SUP>&#91;[[#Note|nota 1]]&#93;</sup>
  
  
Riga 28: Riga 28:
 
   p = Alloc(SizeOf(gb.Byte), 16)
 
   p = Alloc(SizeOf(gb.Byte), 16)
 
   
 
   
<FONT color=#B22222>scanf</font>("%s", p)
+
  <FONT color=#B22222>scanf</font>("%s", p)
 
    
 
    
 
  <FONT Color=gray>' ''Viene restituita una stringa:''</font>
 
  <FONT Color=gray>' ''Viene restituita una stringa:''</font>
Riga 53: Riga 53:
 
   p2 = Alloc(SizeOf(gb.Byte), 16)
 
   p2 = Alloc(SizeOf(gb.Byte), 16)
 
   
 
   
<FONT color=#B22222>scanf</font>("%s %s", p1, p2)
+
  <FONT color=#B22222>scanf</font>("%s %s", p1, p2)
 
    
 
    
 
   Print String@(p1), String@(p2)
 
   Print String@(p1), String@(p2)
Riga 77: Riga 77:
 
   p = Alloc(SizeOf(gb.Integer), 1)
 
   p = Alloc(SizeOf(gb.Integer), 1)
 
    
 
    
<FONT color=#B22222>scanf</font>("%d", p)
+
  <FONT color=#B22222>scanf</font>("%d", p)
 
      
 
      
 
   Print Int@(p)
 
   Print Int@(p)
Riga 99: Riga 99:
 
   p = Alloc(SizeOf(gb.Byte), 1)
 
   p = Alloc(SizeOf(gb.Byte), 1)
 
    
 
    
<FONT color=#B22222>scanf</font>("%d", p)
+
  <FONT color=#B22222>scanf</font>("%d", p)
 
   
 
   
 
   Print Byte@(p)
 
   Print Byte@(p)
Riga 121: Riga 121:
 
   p = Alloc(SizeOf(gb.Float), 1)
 
   p = Alloc(SizeOf(gb.Float), 1)
 
    
 
    
<FONT color=#B22222>scanf</font>("%lf", p)
+
  <FONT color=#B22222>scanf</font>("%lf", p)
 
    
 
    
 
   Print Float@(p)
 
   Print Float@(p)
Riga 143: Riga 143:
 
   Dim dest As New Byte[]
 
   Dim dest As New Byte[]
 
    
 
    
<FONT color=#B22222>scanf</font>("%s", dest)
+
  <FONT color=#B22222>scanf</font>("%s", dest)
 
    
 
    
 
  <FONT Color=gray>' ''Non avendo creato con la parola "New" l'Oggetto vettore, si dovrà usare solo la proprietà ".Data" del vettore, da dereferenziare con la funzione "String@()", per leggere i dati ivi contenuti:''</font>
 
  <FONT Color=gray>' ''Non avendo creato con la parola "New" l'Oggetto vettore, si dovrà usare solo la proprietà ".Data" del vettore, da dereferenziare con la funzione "String@()", per leggere i dati ivi contenuti:''</font>
  Print String@(dest.Data)
+
  Print String@(dest.Data)
 
   
 
   
 
  End
 
  End

Versione attuale delle 07:20, 7 giu 2024

La funzione della libreria di C

int scanf (const char *__restrict __format, ...)

legge l'input da stdin. Essa consente di inserire dati nello standard input. Il dato inserito e contenuto nel scondo parametro, o in ciascun parametro (se previsti più di uno) diverso dal primo, viene restituito formattato in base alla stringa di formattazione format. Per ottenere dunque più dati, distinti fra loro, formattati, bisognerà prevedere un numero di argomenti (diversi dal primo) pari al numeri dei dati predetti.
Va precisato che la stringa di formattazione è costituita dal carattere % e da altro carattere in base al tipo di valore immesso nell'input, ed in particolare:

"%c" per ottenere un carattere;
"%d" per ottenere un intero;
"%f" per ottenere un Float;
"%s" per ottenere una stringa (priva di spazi !);
"%p" per ottenere un indirizzo di memoria.

La Direttiva di conversione "s" con scanf( ) accetta una stringa di caratteri non comprendente gli spazi: quando viene incontrato uno spazio, la lettura dell'input si arresta. [nota 1]


Volendola utilizzare in Gambas, bisognerà dichiararla con Extern, nonché dichiarare la libreria di C: libc.so.6, nella quale la funzione è contenuta:

Private Extern scanf(__format As String, argom As Pointer, [qui altri eventuali parametri As Pointer]) As Integer In "libc:6"


Esempio con immissione di una Stringa

In questo esempio si potrà immettere dallo standard Input una stringa, formata da uno o più caratteri, purché priva di spazi. Qualora vengano immessi caratteri separati da caratteri spazio, tutti i caratteri posti alla destra del primo carattere spazio non saranno scritti in console.

' int scanf (const char *__restrict __format, ...)
' Read formatted input from stdin.
Private Extern scanf(__format As String, argom As Pointer) As Integer In "libc:6"
 

Public Sub Main()

 Dim p As Pointer

 p = Alloc(SizeOf(gb.Byte), 16)

 scanf("%s", p)
  
' Viene restituita una stringa:
 Print String@(p)

 Free(p)

End


In questo altro esempio si potranno immettere dallo standard Input due (o più) dati separati da uno spazio. [Nota 1]

' int scanf (const char *__restrict __format, ...)
' Read formatted input from stdin.
Private Extern scanf(__format As String, argom1 As Pointer, argom2 As Pointer) As Integer In "libc:6"
 

Public Sub Main()

 Dim p1, p2 As Pointer

 p1 = Alloc(SizeOf(gb.Byte), 16)

 p2 = Alloc(SizeOf(gb.Byte), 16)

 scanf("%s %s", p1, p2)
  
 Print String@(p1), String@(p2)

 Free(p1)
 Free(p2)

End


Esempio con Intero

In questo esempio inseriamo un valore numerico intero:

' int scanf (const char *__restrict __format, ...)
' Read formatted input from stdin.
Private Extern scanf(__format As String, argom As Pointer) As Integer In "libc:6"
 

Public Sub Main()

 Dim p As Pointer

 p = Alloc(SizeOf(gb.Integer), 1)
 
 scanf("%d", p)
   
 Print Int@(p)

 Free(p)

End


Esempio con un Carattere (tipo Byte)

In questo esempio inseriamo un Carattere (tipo Byte). Verrà restituito in console il valore ASCII del carattere immesso:

' int scanf (const char *__restrict __format, ...)
' Read formatted input from stdin.
Private Extern scanf(__format As String, argom As Pointer) As Integer In "libc:6"
 

Public Sub Main()

 Dim p As Pointer

 p = Alloc(SizeOf(gb.Byte), 1)
 
 scanf("%d", p)

 Print Byte@(p)

 Free(p)
  
End


Esempio con un valore di tipo Float

In questo esempio inseriamo un valore numerico in virgola mobile di tipo Float. Bisognerà avere l'accortezza di rispettare il simbolo locale (per noi la virgola) quale segno di distinzione fra la parte intera e quella decimale del numero in virgola mobile.

' int scanf (const char *__restrict __format, ...)
' Read formatted input from stdin.
Private Extern scanf(__format As String, argom As Pointer) As Integer In "libc:6"
 

Public Sub Main()

 Dim p As Pointer
  
 p = Alloc(SizeOf(gb.Float), 1)
  
 scanf("%lf", p)
  
 Print Float@(p)
  
 Free(p)
  
End


Uso di un vettore di tipo Byte[ ] al posto di una variabile di tipo Puntatore

Ovviamente al posto di una variabile di tipo Puntatore si potrà fare uso di un vettore di tipo Byte[ ]:

Library "libc:6"

' int scanf (const char *__restrict __format, ...)
' Read formatted input from stdin.
Private Extern scanf(__format As String, argom As Byte[]) As Integer In "libc:6"


Public Sub Main()
 
 Dim dest As New Byte[]
  
 scanf("%s", dest)
  
' Non avendo creato con la parola "New" l'Oggetto vettore, si dovrà usare solo la proprietà ".Data" del vettore, da dereferenziare con la funzione "String@()", per leggere i dati ivi contenuti:
 Print String@(dest.Data)

End


Note

[1] Per evitare tale "limite", imposto dal carattere dello "spazio" con la funzione "scanf()", è opportuno utilizzare la funzione esterna fgets( ).