Procedura: utilizzare puntatori per copiare una matrice di byte (Guida per programmatori C#)

Aggiornamento: novembre 2007

Nell'esempio riportato di seguito vengono utilizzati i puntatori per copiare byte da una matrice a un'altra che utilizza puntatori.

Nell'esempio viene utilizzata la parola chiave unsafe, che consente l'utilizzo di puntatori all'interno del metodo Copy. Per dichiarare i puntatori nelle matrici di origine e destinazione, viene utilizzata l'istruzione fixed che blocca la posizione delle matrici di origine e destinazione nella memoria in modo che non vengano rimossi da Garbage Collection. I blocchi di memoria verranno rimossi al completamento del blocco fixed. In questo esempio la funzione Copy utilizza la parola chiave unsafe, pertanto deve essere compilata con l'opzione /unsafe del compilatore.

Esempio

// compile with: /unsafe
class TestCopy
{
    // The unsafe keyword allows pointers to be used within the following method:
    static unsafe void Copy(byte[] src, int srcIndex, byte[] dst, int dstIndex, int count)
    {
        if (src == null || srcIndex < 0 ||
            dst == null || dstIndex < 0 || count < 0)
        {
            throw new System.ArgumentException();
        }

        int srcLen = src.Length;
        int dstLen = dst.Length;
        if (srcLen - srcIndex < count || dstLen - dstIndex < count)
        {
            throw new System.ArgumentException();
        }

        // The following fixed statement pins the location of the src and dst objects
        // in memory so that they will not be moved by garbage collection.
        fixed (byte* pSrc = src, pDst = dst)
        {
            byte* ps = pSrc;
            byte* pd = pDst;

            // Loop over the count in blocks of 4 bytes, copying an integer (4 bytes) at a time:
            for (int i = 0 ; i < count / 4 ; i++)
            {
                *((int*)pd) = *((int*)ps);
                pd += 4;
                ps += 4;
            }

            // Complete the copy by moving any bytes that weren't moved in blocks of 4:
            for (int i = 0; i < count % 4 ; i++)
            {
                *pd = *ps;
                pd++;
                ps++;
            }
        }
    }

    static void Main()
    {
        byte[] a = new byte[100];
        byte[] b = new byte[100];

        for (int i = 0; i < 100; ++i)
        {
            a[i] = (byte)i;
        }

        Copy(a, 0, b, 0, 100);
        System.Console.WriteLine("The first 10 elements are:");

        for (int i = 0; i < 10; ++i) 
        {
            System.Console.Write(b[i] + " ");
        }
        System.Console.WriteLine("\n");
    }
}
/* Output:
    The first 10 elements are:
    0 1 2 3 4 5 6 7 8 9        
*/

Vedere anche

Attività

Esempio di codice unsafe

Concetti

Guida per programmatori C#

Riferimenti

Codice unsafe e puntatori (Guida per programmatori C#)

/unsafe (attivare la modalità non protetta) (opzioni del compilatore C#)

Altre risorse

Garbage Collection