前面的東西都比較基礎,後面的這個才是真正關鍵的地方。
示例代碼:
#include <iostream> #include <stdlib.h> int main(int argc, char *argv[]) { //argc 指的是參數個數 // argv[0]指的是程序的名字 // argv[1]值的是程序執行的第一個參數 int array[10]={1023,2,3,4,5,6}; int *p = &array[0]; int *p1 = array; printf("%p,%p\n",array,&array[0]); //十六位的地址 //兩個地址的值,並且兩個地址相同。 printf("*p = %d\n",*p); //1 printf("*p1 = %d\n",*p1); //1 printf("sizeof(array) = %d,sizeof(p1) = %d\n",sizeof(array),sizeof(p1)); //40,8 printf("%d,%d\n",sizeof(int *),sizeof(char *)); //8,8 printf("array =%p,*array =%p,&array = %p\n",array,*array,&array); //地址的值,跟上面的結果一樣的,15個0後面1,(如果是32位的操作系統的話,應該是7個0後面一個1),地址的值,跟最上面一樣 //這個結果是什麼呢? printf("%d\n",*((char *)p1+1)); //這個地方很奇怪,總是覺得有問題。 //但是好像就是 0啊。 return 0; }
運行結果:
這個地方多少有點兒出入,就是為了把那個 結果試出來。所以能看得出來,開始數組裡面第一個數字給的是1.
來看看為什麼最後一行的結果是3.前面的不知道為什麼的同學可以看看這個地址裡面書寫的內容:
http://www.cnblogs.com/letben/p/5213967.html
void function2(void){ //上面的如果看懂了的話,下面的都比較簡單了 char buf[10] = {"abcdef"}; char *pc = buf; printf("%c\n",*(pc+3)); int i = 0x12345678; char *cpi = (char *) &i; printf("%x,%x,%x,%x\n",*(cpi+0),*(cpi+1),*(cpi+2),*(cpi+3)); }
運行結果:
這個表現出操作系統相關性,如果是一般的windows,或者linux都是這種先輸出小端的,如果是服務器型的unix的話,就會出現12,34,56,78的結果。
利用指針進行賦值:
代碼:
/** 利用指針進行賦值。 */ void function3(void){ int array[10]={0}; int *p = array; for(int i = 0;i<10;i++){ scanf("%d",p++); } for(int i= 0;i<10;i++){ printf("%d\n",array[i]); } }
運行結果:
/** 指針數組 與數組指針 */ void function4(void){ char *s[10];//指針數組 char (*s1)[10];//數組指針 //第一個表達的意思是,有一個數組,裡面有10個元素,每個元素都是一個指向 字符數組 類型 的 指針變量。 //所以可以有 char c1[2]; char c2[3]; char c3[4]; s[1] = c1; s[2] = c2; s[3] = c3; //第二個是數組指針,是一個指向有10個字符大小的字符數組的指針變量。 char cc[2][10]; //[Error] cannot convert 'char [2][5]' to 'char (*)[10]' in assignment s1 = cc; s1 = &cc[1]; //這些東西 明天好好在理解一下 int i; int * p; p = &i; //同理: char mychars[10]; s1 = &mychars; }