《C與指針》讀書筆記五
指針在C語言編程中應用廣泛。并且與數組有交集。很多情況下數組與指針結合使用可以事半功倍。我們可以聲明一個數組,并且將其初始化。
本文引用地址:http://www.104case.com/article/201608/295453.htmint arrary[10]={ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
數組在聲明時可以同時初始化。以上語句的結果就是聲明一個數組,同時初始化該數組。等價于以下語句:
int arrary[10];
int i;
for( i = 0; i < sizeof (arrary ); i++ )
{
arrary[i] = i;
}
初始化結束后,在內存中存儲如下:
數組是通過數組名和下標的結合使用的。arrary是數組名,相當于數組的第一個成員的首地址。下標相當于偏移量。arrary[2]的地址其實相當于arrary+2*sizeof(int)。int是數據類型。在有的系統中是4,在有些系統中是2。在此我們假設int類型是4個字節。
既然數組通過地址索引使用的,指針也是地址,那么之間就有天然的共性。所以必定有相同之處。比如我們要實現一個數組復制給另外一個數組。可以使用參照一個產品手冊中提供的示例代碼。
#include
#include
void tst_memcpy (void) {
char src1 [100] = "Copy this string to dst1";
char dst1 [100];
char *p;
p = memcpy (dst1, src1, sizeof (dst1));
printf ("dst = "%s"n", p);
}
作者通過memcpy實現了src1 數組復制給dst1。我們可以看一下memcpy函數的原型說明。
void *memcpy (
void *dest, /* destination buffer */
void *src, /* source buffer */
int len); /* bytes to copy */
dest與src都是指針,但是我們傳入參數卻是數組。p = memcpy (dst1, src1, sizeof (dst1));
dst1與src1是我們聲明的數組。正因為dst1與src1也是地址,與指針意義完全相同,所以實現了數組復制。
memcpy是C編譯器提供標準庫函數。我們也可以自己實現一下,因為是示例,就不過多考慮安全性問題了。
void *MemCopy( void *dest, void *src, int len)
{
int i;
char *temp;
temp = dest;
for( i =0; i < len; i++)
{
temp[i] = src[i];
}
return dest;
}
temp[i] = src[i];我們仍然按照數組方式處理了指針。在這本書上,我看到一種表示方法。arrary[2]其實等價于*(arrary+2).也就是
arrary[2] = 2;等價于*(arrary+2)=2;
m = arrary[2]; 等價于m =*(arrary+2);
熟練以后,如果遇到需要數組復制的,可以自己動手實現。就不使用庫函數了。使用指針傳遞一個數組,確實在傳參方面效率提高很多。比如排序,只要傳入數組的首地址和長度即可。
評論