版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
元素均為指針類型數(shù)據(jù)的數(shù)組,稱為指針數(shù)組
定義形式為:
類型關(guān)鍵字*數(shù)組名[數(shù)組長度];例如
char*pStr[5];
pStr[5]*char四、指針數(shù)組1例main(){
inti;
char
str[][10]={"Pascal","Basic","Fortran","Java","VisualC"};
for(i=0;i<5;i++){printf("%s\n",str[i]);
}}strstr[0]Pascalstr[1]str[2]str[3]BasicFortranJava二維數(shù)組字符串VisualCstr[4]2例main(){
inti;
char
*ptr[]={"Pascal","Basic","Fortran","Java","VisualC"};
for(i=0;i<5;i++){printf("%s\n",ptr[i]);
}}ptr[0]Pascalptr[1]ptr[2]ptr[3]BasicFortranJavaptr指針數(shù)組字符串ptrVisualCptr[4]3例:字符串按字典順序排序—二維數(shù)組編程char
str[N][10]={"Pascal","Basic","Fortran","Java","VisualC"};for(i=0;i<N-1;i++) {
for(j=i+1;j<N;j++) {
if(strcmp(str[j],str[i])<0) {
strcpy(temp,str[i]); strcpy(str[i],str[j]); strcpy(str[j],temp); } }}strstrstrstrstrstrstrstrstrstr4例:字符串按字典順序排序—指針數(shù)組編程char
*ptr[N]={"Pascal","Basic","Fortran","Java","VisualC"};for(i=0;i<N-1;i++){
for(j=i+1;j<N;j++){
if(strcmp(ptr[j],ptr[i])<0){
temp=ptr[i]; ptr[i]=ptr[j]; ptr[j]=temp;} }}指針數(shù)組ptr字符串排序前Pascal\0Basic\0Fortran\0Java\0VisualC\0ptr[0]ptr[1]ptr[2]ptr[3]ptr[4]指針數(shù)組ptr字符串排序后Pascal\0Basic\0Fortran\0Java\0VisualC\0ptr[0]ptr[1]ptr[2]ptr[3]ptr[4]5命令行參數(shù)main()函數(shù)既可以是無參函數(shù),也可以是有參的函數(shù).向其傳遞參數(shù),只能由程序之外傳遞而來.
main(intargc,char*argv[])當你把main函數(shù)寫成這樣時argc的值為程序執(zhí)行時參數(shù)的數(shù)目(包括命令本身)argv[i]為指向第i個參數(shù)的字符指針這兩個內(nèi)設(shè)形參用于接收命令行參數(shù)通過命令行參數(shù),使用戶可以根據(jù)需要來決定我們的程序干什么、怎么干6例:演示命令行參數(shù)與main函數(shù)各形參之間的關(guān)系voidmain(intargc,char*argv[]){
inti; printf("Theprogramnameis:%s\n",argv[0]);
if(argc>1) { printf("Theotherargumentsarefollowing:\n");
for(i=1;i<argc;i++) { printf("%s\n",argv[i]); } } getch();}argv[0]echo.exeargv[1]argv[2]helloworldptr指針數(shù)組字符串name7指針型函數(shù)一個函數(shù)可以返回一個int型、float型、char型的數(shù)據(jù),也可以返回一個指針類型的數(shù)據(jù),即地址。返回指針值的函數(shù)(簡稱指針函數(shù))的定義格式如下:
函數(shù)類型*函數(shù)名([參數(shù)表])
例int*f(intx,inty)8例求一維數(shù)組的最大值及其下標int*findMax(intx[]){ inti,j; j=0; for(i=1;i<5;i++) if(x[i]>x[j]) j=i; return(&x[j]);}voidmain(){ inta[5]={3,6,1,9,12},*max; max=findMax(a); printf("max[%d]=%d",max-a,*max);}9五、多級指針和動態(tài)指針1.概念及定義定義:指向指針的指針一級指針:指針變量中存放目標變量的地址p1&p2&i3P2(指針變量)i(整型變量)例int**p1;int*p2;inti=3;p2=&i;p1=&p2;**p1=5;二級指針:指針變量中存放一級指針變量的地址例int*p;inti=3;p=&i;*p=5;&i3P(指針變量)i(整型變量)一級指針二級指針一級指針目標變量前面學的行指針是個二級指針10(1)定義形式:數(shù)據(jù)類型
**指針名;如int**p;inti=5,*pp;(2)賦值p=&i;pp=&p;(3)引用方法pp的值*pp的值**pp的值多級指針定義形式112.動態(tài)指針為什么要動態(tài)分配內(nèi)存?
當事先不知道所需要處理的數(shù)據(jù)有多大時,使用靜態(tài)數(shù)組,若數(shù)組開辟得太大,則浪費內(nèi)存資源(甚至可能不成功);若開辟得太小,又不能滿足計算需要。采用動態(tài)分配內(nèi)存的方法,使用完畢,再釋放內(nèi)存,以備其它程序使用。C語言中提供了幾個標準函數(shù),以實現(xiàn)內(nèi)存的分配和釋放。12動態(tài)分配內(nèi)存#include<stdlib.h>
#include<alloc.h>void*malloc(unsigned
intsize);向系統(tǒng)申請大小為size的內(nèi)存塊,把首地址返回。如果申請不成功,返回NULLvoid*calloc(unsignedintnum,
unsigned
intsize);向系統(tǒng)申請num個size大小的內(nèi)存塊,把首地址返回。如果申請不成功,返回NULLvoidfree(void*p);釋放由malloc()和calloc()申請的內(nèi)存塊。p是指向此塊的指針void*類型的指針可以指向任意類型的變量13動態(tài)數(shù)組一維動態(tài)數(shù)組 int*p=NULL; printf("Pleaseenterarraysize:"); scanf("%d",&n); p=(int*)malloc(n*sizeof(int)); …
p[i]//像使用一維數(shù)組一樣使用 …二維動態(tài)數(shù)組 printf("Pleaseenterarraysizem,n:"); scanf("%d,%d",&m,&n); p=(int*)calloc(m*n,sizeof(int)); …
p[i*n+j]);//像使用一維數(shù)組一樣使用 …14函數(shù)指針(選學)1.函數(shù)指針的概念
一個函數(shù)在編譯時,被分配了一個入口地址,這個地址就稱為該函數(shù)的指針??梢杂靡粋€指針變量指向一個函數(shù),然后通過該指針變量調(diào)用此函數(shù)152.指向函數(shù)的指針變量(1)定義格式
函數(shù)類型(*指針變量)();
注意:“*指針變量”外的括號不能缺,否則成了返回指針值的函數(shù)。
例如,int(*fp)();/*fp為指向int函數(shù)的指針變量*/(2)賦值
函數(shù)名代表該函數(shù)的入口地址。因此,可用函數(shù)名給指向函數(shù)的指針變量賦值。
指向函數(shù)的指針變量=[&]函數(shù)名;
注意:函數(shù)名后不能帶括號和參數(shù);函數(shù)名前的“&”符號是可選的。16(3)調(diào)用格式
(*函數(shù)指針變量)([實參表])3.指向函數(shù)的指針變量作函數(shù)參數(shù)指向函數(shù)的指針變量的常用用途之一,就是將函數(shù)指針作參數(shù),傳遞到其它函數(shù)。函數(shù)名作實參時,因為要缺省括號和參數(shù),造成編譯器無法判斷它是一個變量還是一個函數(shù),所以必須加以函數(shù)說明。注意:對指向函數(shù)的指針變量,
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024物業(yè)租賃中的讓與擔保 甲方與乙方合同范本
- 2025年度體育賽事代理合同終止及賽事推廣合作協(xié)議4篇
- 2025年度商鋪物業(yè)管理與應(yīng)急響應(yīng)預(yù)案合同4篇
- 2025年度變壓器租賃及電力設(shè)備租賃期滿續(xù)租合同3篇
- 2024藝人廣告代言服務(wù)合同范本
- 2025年度主題餐廳投資合作協(xié)議范本3篇
- 2025年度水果種植基地與電商平臺合作合同3篇
- 2024跨境電子商務(wù)融資代建合同
- 2025年度安全生產(chǎn)信息化服務(wù)合同范本3篇
- 2025年度新能源汽車充電站車棚建設(shè)與運營承包合同4篇
- 2024高考復習必背英語詞匯3500單詞
- 消防控制室值班服務(wù)人員培訓方案
- 《貴州旅游介紹》課件2
- 2024年中職單招(護理)專業(yè)綜合知識考試題庫(含答案)
- 無人機應(yīng)用平臺實施方案
- 挪用公款還款協(xié)議書范本
- 事業(yè)單位工作人員年度考核登記表(醫(yī)生個人總結(jié))
- 盾構(gòu)隧道施工數(shù)字化與智能化系統(tǒng)集成
- 【企業(yè)盈利能力探析文獻綜述2400字】
- 2019年醫(yī)養(yǎng)結(jié)合項目商業(yè)計劃書
- 2023年店鋪工程主管年終業(yè)務(wù)工作總結(jié)
評論
0/150
提交評論