從頭學(xué)習(xí)C語言之指針和數(shù)組
指針和數(shù)組:
數(shù)組名其實是數(shù)組第一個元素的地址。 %p用來打印地址,為十六進制 &:取址操作符
如果用一個指針指向數(shù)組,應(yīng)該怎么做呢?
- char *p;
- p=a;//語句1
- p=&a[0];//語句2
指針的運算:
- 當(dāng)指針指向數(shù)組元素的時候,我們可以對指針變量進行加減運算,這樣做的意義相當(dāng)于只想距離指針?biāo)谖恢孟蚯盎蛳蚝蟮趎個元素。
- 對比標(biāo)準(zhǔn)的下標(biāo)法訪問數(shù)組元素,這種使用指針進行間接訪問的方法叫做指針法。
- 需要鄭重強調(diào)的是:p+1并不是簡單的將地址加1,二十只想數(shù)組的下一個元素。
linux命令:12s/a/b/g:把第十二行的所有a替換為b
示例:
例一:
從標(biāo)準(zhǔn)輸入流讀取字符需要取址操作符(scanf),并且用&來址
#include<stdio.h> int main() { int a; int *p=&a; printf("請輸入一個整數(shù):"); scanf("%d",&a); printf("a=%d\n",a); printf("請重新輸入一個整數(shù)"); scanf("%d",p); printf("a=%d\n",a); return 0; }
例二:
得出數(shù)組名是一個地址信息
#include<stdio.h> int main() { char str[120]; printf("請輸入魚C的域名:"); scanf("%s",str); printf("魚C工作室的域名是:%s\n",str); return 0; }
例三:
得出數(shù)組名其實是數(shù)組第一個元素的地址!
#include<stdio.h> int main() { char str[120]; printf("請輸入魚C的域名:"); scanf("%s",str); //printf("魚C工作室的域名是:%s\n",str); printf("str的地址是:%p\n",str); printf("str的地址是:%p\n",&str[0]); return 0; }
例四:
得出數(shù)組中的元素地址依次排列,元素空間相同按類型所占字節(jié)數(shù)排列
#include<stdio.h> int main() { char a[]="fishc"; int b[5]={1,2,3,4,5}; float c[5]={1.1,2.2,3.3,4.4,5.5}; double d[5]={1.1,2.2,3.3,4.4,5.5}; printf("a[0]->%p,a[1]->%p,a[2]->%p\n",&a[0],&a[1],&a[2]); printf("b[0]->%p,b[1]->%p,b[2]->%p\n",&b[0],&b[1],&b[2]); printf("c[0]->%p,c[1]->%p,c[2]->%p\n",&c[0],&c[1],&c[2]); printf("d[0]->%p,d[1]->%p,d[2]->%p\n",&d[0],&d[1],&d[2]); return 0; }
例五:
得出數(shù)組中的元素地址依次排列,元素空間相同按類型所占字節(jié)數(shù)排列
#include<stdio.h> int main() { char a[]="fishc"; int b[5]={1,2,3,4,5}; float c[5]={1.1,2.2,3.3,4.4,5.5}; double d[5]={1.1,2.2,3.3,4.4,5.5}; int *p=b; printf("*p=%d,*(p+1)=%d,*(p+2)=%d\n",*p,*(p+1),*(p+2)); printf("*b=%d,*(b+1)=%d,*(b+2)=%d\n",*b,*(b+1),*(b+2)); printf("a[0]->%p,a[1]->%p,a[2]->%p\n",&a[0],&a[1],&a[2]); printf("b[0]->%p,b[1]->%p,b[2]->%p\n",&b[0],&b[1],&b[2]); printf("c[0]->%p,c[1]->%p,c[2]->%p\n",&c[0],&c[1],&c[2]); printf("d[0]->%p,d[1]->%p,d[2]->%p\n",&d[0],&d[1],&d[2]); return 0; }
例六:指針變量直接定義并賦值字符串
#include<stdio.h> #include<string.h> int main() { char *str="i love fishc.com!"; int i,length; length=strlen(str); for(i=0;i<length;i++) { printf("%c",str[i]); } printf("\n"); return 0; }
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
簡單了解C語言中直接插入排序與直接選擇排序?qū)崿F(xiàn)
這篇文章主要介紹了C語言中直接插入排序與直接選擇排序?qū)崿F(xiàn),插入排序的基本操作就是將一個數(shù)據(jù)插入到已經(jīng)排好序的有序數(shù)據(jù)中,從而得到一個新的、個數(shù)加一的有序數(shù)據(jù),需要的朋友可以參考下2016-03-03深入探討C語言中局部變量與全局變量在內(nèi)存中的存放位置
本篇文章是對在C語言中局部變量與全局變量在內(nèi)存中的存放位置進行了詳細的分析介紹,需要的朋友參考下2013-05-05C++中priority_queue的使用與模擬實現(xiàn)
本文主要介紹了C++中priority_queue的使用與模擬實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02