Differenze tra le versioni di "Memset ()"

Da Gambas-it.org - Wikipedia.
 
(Una versione intermedia di uno stesso utente non è mostrata)
Riga 7: Riga 7:
 
Volendola utilizzare in Gambas, bisognerà dichiararla con ''Extern'', nonché bisognerà dichiarare la libreria di C: ''libc.so.6'', nella quale la funzione è contenuta:
 
Volendola utilizzare in Gambas, bisognerà dichiararla con ''Extern'', nonché bisognerà dichiarare la libreria di C: ''libc.so.6'', nella quale la funzione è contenuta:
 
  Private <FONT color=#B22222>Extern memset</font>(buffer As Pointer, c As Byte, count As Long) In "<FONT color=#B22222>libc:6</font>"
 
  Private <FONT color=#B22222>Extern memset</font>(buffer As Pointer, c As Byte, count As Long) In "<FONT color=#B22222>libc:6</font>"
Il primo argomento, oltre a essere di tipo ''Puntatore'', potrà essere anche un Vettore.
+
In questo esempio si modificheranno i primi 4 caratteri di una stringa:
 
+
<FONT color=Gray>' ''void * memset(void *buffer, int c, size_t count)''
 +
' ''Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.''</font>
 +
Private Extern<FONT color=#B22222> memset</font>(buffer As Pointer, c As Integer, count As Long) In "<FONT color=#B22222>libc:6</font>"
 +
 +
 +
Public Sub Main()
 +
 +
  Dim p As Pointer
 +
 +
  p = Alloc("Testo qualsiasi")
 +
 +
  <FONT color=#B22222>memset</font>(p, Asc("a"), 4)
 +
 +
  Print String@(p)
 +
 +
<FONT color=Gray>' ''Dealloca l'area di memoria precedentemente allocata e si assicura che il Puntatore non punti ad alcun indirizzo rilevante di memoria:''</font>
 +
  Free(p)
 +
  p = 0
 +
 +
End
  
Semplice esempio di uso in Gambas, nel quale si assegna il valore 100 agli elementi di un vettore di tipo "Byte[]":
+
Ovviamente la destinazione potrà essere anche un ''Puntatore'', rappresentato dalla Proprietà ".Data" di un vettore:
 
  <FONT color=Gray>' ''void * memset(void *buffer, int c, size_t count)''
 
  <FONT color=Gray>' ''void * memset(void *buffer, int c, size_t count)''
 
  ' ''Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.''</font>
 
  ' ''Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.''</font>
  Private Extern<FONT color=#B22222> memset</font>(dest As Byte[], c As Integer, count As Long) In "<FONT color=#B22222>libc:6</font>"
+
  Private Extern<FONT color=#B22222> memset</font>(dest As Pointer, c As Integer, count As Long) In "<FONT color=#B22222>libc:6</font>"
 
   
 
   
 
   
 
   
  '''Public''' Sub Main()
+
  Public Sub Main()
 
   
 
   
 
   Dim bb As New Byte[10]
 
   Dim bb As New Byte[10]
 
   Dim b As Byte
 
   Dim b As Byte
 
   
 
   
   <FONT color=#B22222>memset</font>(bb, 100, 10)
+
<FONT color=Gray>' ''In questo caso al primo argomento della funzione passiamo il ''Puntatore'' all'area di memoria del vettore, ove sono memorizzati i dati contenuti dagli elementi del vettore medesimo. L'indirizzo di memoria di detta area è restituita dalla Proprietà ".Data" del vettore:''</font>
 +
   memset(bb<FONT color=#B22222>.Data</font>, 100, 10)
 
    
 
    
 
   For Each b In bb
 
   For Each b In bb
Riga 27: Riga 47:
 
   Next
 
   Next
 
    
 
    
  '''End'''
+
  End
Nello stesso esempio la destinazione potrà essere anche un ''Puntatore'', rappresentato dalla Proprietà ".Data" di un vettore:
+
 
 +
===Uso di un vettore nel primo argomento della funzione esterna "memset()"===
 +
Il primo argomento della funzione esterna "memset()", oltre a essere di tipo ''Puntatore'', potrà essere anche un Vettore.
 +
 
 +
Vediamo un semplice esempio, nel quale si assegna il valore 100 agli elementi di un vettore di tipo "Byte[]":
 
  <FONT color=Gray>' ''void * memset(void *buffer, int c, size_t count)''
 
  <FONT color=Gray>' ''void * memset(void *buffer, int c, size_t count)''
 
  ' ''Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.''</font>
 
  ' ''Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.''</font>
  Private Extern<FONT color=#B22222> memset</font>(dest As Pointer, c As Integer, count As Long) In "<FONT color=#B22222>libc:6</font>"
+
  Private Extern<FONT color=#B22222> memset</font>(dest As Byte[], c As Integer, count As Long) In "<FONT color=#B22222>libc:6</font>"
 
   
 
   
 
   
 
   
  '''Public''' Sub Main()
+
  Public Sub Main()
 
   
 
   
 
   Dim bb As New Byte[10]
 
   Dim bb As New Byte[10]
 
   Dim b As Byte
 
   Dim b As Byte
 
   
 
   
<FONT color=Gray>' ''In questo caso al primo argomento della funzione passiamo il ''Puntatore'' all'area di memoria del vettore, ove sono memorizzati i dati contenuti dagli elementi del vettore medesimo. L'indirizzo di memoria di detta area è restituita dalla Proprietà ".Data" del vettore:''</font>
+
   <FONT color=#B22222>memset</font>(bb, 100, 10)
   memset(bb<FONT color=#B22222>.Data</font>, 100, 10)
 
 
    
 
    
 
   For Each b In bb
 
   For Each b In bb
Riga 46: Riga 69:
 
   Next
 
   Next
 
    
 
    
  '''End'''
+
  End
  
 
Altro esempio nel quale si azzereranno tutti gli elementi di un vettore di tipo "Integer[]":
 
Altro esempio nel quale si azzereranno tutti gli elementi di un vettore di tipo "Integer[]":
Riga 53: Riga 76:
 
  Private Extern<FONT color=#B22222> memset</font>(dest As integer[], c As Integer, count As Long) In "<FONT color=#B22222>libc:6</font>"
 
  Private Extern<FONT color=#B22222> memset</font>(dest As integer[], c As Integer, count As Long) In "<FONT color=#B22222>libc:6</font>"
 
   
 
   
  '''Public''' Sub Main()
+
  Public Sub Main()
 
   
 
   
 
   Dim ii As Integer[] = [1, 2, 3, 4, 5]
 
   Dim ii As Integer[] = [1, 2, 3, 4, 5]
Riga 65: Riga 88:
 
   Next
 
   Next
 
   
 
   
  '''End'''
+
  End
 
 
In quest'altro esempio si modificheranno i primi 4 caratteri di una stringa:
 
<FONT color=Gray>' ''void * memset(void *buffer, int c, size_t count)''
 
' ''Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.''</font>
 
Private Extern<FONT color=#B22222> memset</font>(buffer As Pointer, c As Integer, count As Long) In "<FONT color=#B22222>libc:6</font>"
 
 
 
'''Public''' Sub Main()
 
 
  Dim p As Pointer
 
 
  p = Alloc("Testo qualsiasi")
 
 
  <FONT color=#B22222>memset</font>(p, Asc("a"), 4)
 
 
  Print String@(p)
 
 
  Free(p)
 
  p = 0
 
 
'''End'''
 

Versione attuale delle 14:15, 13 giu 2024

La funzione della libreria di C

void * memset( void *buffer, int c, size_t count )

copia il valore di "c" nell'area di memoria (puntata da una variabile di tipo Puntatore ) per una quantità stabilita nell'argomento count.
V'è da precisare che il valore del secondo parametro viene passato come un intero (int ), ma la funzione stessa riempie il blocco di memoria utilizzando la conversione di questo valore nel tipo "unsigned char " (ossia il tipo Byte di Gambas).


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

Private Extern memset(buffer As Pointer, c As Byte, count As Long) In "libc:6"

In questo esempio si modificheranno i primi 4 caratteri di una stringa:

' void * memset(void *buffer, int c, size_t count)
' Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.
Private Extern memset(buffer As Pointer, c As Integer, count As Long) In "libc:6"


Public Sub Main()

 Dim p As Pointer

 p = Alloc("Testo qualsiasi")

 memset(p, Asc("a"), 4)

 Print String@(p)

' Dealloca l'area di memoria precedentemente allocata e si assicura che il Puntatore non punti ad alcun indirizzo rilevante di memoria:
 Free(p)
 p = 0

End

Ovviamente la destinazione potrà essere anche un Puntatore, rappresentato dalla Proprietà ".Data" di un vettore:

' void * memset(void *buffer, int c, size_t count)
' Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.
Private Extern memset(dest As Pointer, c As Integer, count As Long) In "libc:6"


Public Sub Main()

 Dim bb As New Byte[10]
 Dim b As Byte

' In questo caso al primo argomento della funzione passiamo il Puntatore all'area di memoria del vettore, ove sono memorizzati i dati contenuti dagli elementi del vettore medesimo. L'indirizzo di memoria di detta area è restituita dalla Proprietà ".Data" del vettore:
 memset(bb.Data, 100, 10)
  
 For Each b In bb
   Print b
 Next
 
End

Uso di un vettore nel primo argomento della funzione esterna "memset()"

Il primo argomento della funzione esterna "memset()", oltre a essere di tipo Puntatore, potrà essere anche un Vettore.

Vediamo un semplice esempio, nel quale si assegna il valore 100 agli elementi di un vettore di tipo "Byte[]":

' void * memset(void *buffer, int c, size_t count)
' Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.
Private Extern memset(dest As Byte[], c As Integer, count As Long) In "libc:6"


Public Sub Main()

 Dim bb As New Byte[10]
 Dim b As Byte

 memset(bb, 100, 10)
  
 For Each b In bb
   Print b
 Next
 
End

Altro esempio nel quale si azzereranno tutti gli elementi di un vettore di tipo "Integer[]":

' void * memset(void *buffer, int c, size_t count)
' Copies the character c (an unsigned char) to the first count characters of the string pointed to, by the argument buffer.
Private Extern memset(dest As integer[], c As Integer, count As Long) In "libc:6"

Public Sub Main()

 Dim ii As Integer[] = [1, 2, 3, 4, 5]
 Dim i As Integer

' Se il vettore è di tipo "Integer", allora il valore del 3° parametro della funzione va moltiplicato per 4, poiché il valore di tipo "Intero" occupa nella memoria 4 byte:
 memset(ii, 0, ii.Count * SizeOf(gb.Integer))

 For Each i in ii
   Print i
 Next

End