




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、鄭州輕工業(yè)學(xué)院課程設(shè)計報告書題 目:Reverse圖像求反 學(xué) 院:計算機與通信工程學(xué)院 專 業(yè):電子信息科學(xué)與技術(shù) 姓 名:學(xué) 號: 指導(dǎo)老師: 實驗?zāi)康?了解數(shù)字圖像處理的基本原理;2學(xué)習(xí)灰度圖像求反處理技術(shù);3掌握數(shù)字圖像處理在DSP上的實現(xiàn)。實驗設(shè)備計算機,CCS 2.0版軟件,DSP仿真器,實驗箱。實驗要求1).了解使用DSP實現(xiàn)圖像求反的方法2).分析圖像如何輸入,并存儲在什么位置。3).修改程序,實現(xiàn)圖像對比度增強。實驗設(shè)計流程圖五、程序代碼:1、主程序:#define IMAGEWIDTH 80#define IMAGEHEIGHT 80#define MODEGRAYBAR
2、0#define MODEGRAY 1#define MODEPHOTO1 2#define MODEPHOTO2 3#define MODEPHOTO3 4#define MODEPHOTO4 5void InitImage(unsigned int nMode,unsigned char *pImage,int nWidth,int nHeight);unsigned char dbImageIMAGEWIDTH*IMAGEHEIGHT;unsigned char dbTargetImageIMAGEWIDTH*IMAGEHEIGHT;/* 直方圖統(tǒng)計實驗程序 */int main()In
3、itImage(MODEGRAYBAR,dbImage,IMAGEWIDTH,IMAGEHEIGHT);Reverse(IMAGEWIDTH,IMAGEHEIGHT);InitImage(MODEGRAY,dbImage,IMAGEWIDTH,IMAGEHEIGHT);/BreakPointReverse(IMAGEWIDTH,IMAGEHEIGHT);InitImage(MODEPHOTO1,dbImage,IMAGEWIDTH,IMAGEHEIGHT);/BreakPointReverse(IMAGEWIDTH,IMAGEHEIGHT);InitImage(MODEPHOTO2,dbIma
4、ge,IMAGEWIDTH,IMAGEHEIGHT);/BreakPointReverse(IMAGEWIDTH,IMAGEHEIGHT);InitImage(MODEPHOTO3,dbImage,IMAGEWIDTH,IMAGEHEIGHT);/BreakPointReverse(IMAGEWIDTH,IMAGEHEIGHT);InitImage(MODEPHOTO4,dbImage,IMAGEWIDTH,IMAGEHEIGHT);/BreakPointReverse(IMAGEWIDTH,IMAGEHEIGHT);while (1);/BreakPoint2、初始化程序#include#d
5、efine MODEGRAYBAR 0#define MODEGRAY 1#define MODEPHOTO1 2#define MODEPHOTO2 3#define MODEPHOTO3 4#define MODEPHOTO4 5#define MODEBLOCK 6#define MODEINCLINE 7#define MODEFPHOTO 8#define GRAYBARLEVEL 16 void ReadImage(unsigned char *pImage,char *cFileName,int nWidth,int nHeight);void InitImage(unsigne
6、d int nMode,unsigned char *pImage,int nWidth,int nHeight)int x,y,nWork,nWork1;unsigned char *pWork;int nPointx=nWidth/2;int nPointy=nHeight/2;float fWork;switch ( nMode )case MODEGRAYBAR:pWork=pImage; nWork=256/GRAYBARLEVEL; nWork1=nHeight/GRAYBARLEVEL;for ( y=0;ynHeight;y+ )for ( x=0;xnWidth;x+,pWo
7、rk+ )(*pWork)=(y/nWork1)*nWork;break;/里面的灰度case MODEGRAY:pWork=pImage; nWork1=nHeight-nPointy; nWork=nWork1*nWork1;/(40,40)nWork1=nWidth-nPointx; nWork+=(nWork1*nWork1);/(40,3200)nWork/=256;/12for ( y=0;ynHeight;y+ )for ( x=0;xnWidth;x+,pWork+ )nWork1=(x-nPointx)*(x-nPointx)+(y-nPointy)*(y-nPointy);
8、nWork1=255-nWork1/nWork;/0到255之間的一個灰度的園,以圓象中心為圓心,255-nwork1/nwork為中心 if ( nWork1255 )nWork1=255;(*pWork)=nWork1;/ pWork=pImage;break;case MODEPHOTO1:ReadImage(pImage,.DSP.bmp,nWidth,nHeight);break;case MODEPHOTO2:ReadImage(pImage,.1.bmp,nWidth,nHeight);break;case MODEPHOTO3:ReadImage(pImage,.2.bmp,n
9、Width,nHeight);break;case MODEPHOTO4:ReadImage(pImage,.3.bmp,nWidth,nHeight);break;case MODEBLOCK:pWork=pImage;for ( y=0;ynHeight;y+ )for ( x=0;xnWidth;x+,pWork+ )(*pWork)=0;/全黑pWork=pImage+(nHeight/4-1)*nWidth;for ( y=nHeight/4;ynHeight*3/4;y+,pWork+=nWidth )/20,60for ( x=nWidth/4;xnWidth*3/4;x+ )/
10、20,60pWorkx=255;break;/白框case MODEINCLINE:pWork=pImage;for ( y=0;ynHeight;y+ )for ( x=0;xnWidth;x+,pWork+ )(*pWork)=0;/全黑pWork=pImage;fWork=nWidth/nHeight;for ( y=0;ynHeight/4;y+ )for ( x=nWidth/2-fWork*y;xnWidth/2+fWork*y;x+ )pWork(y+nHeight/4)*nWidth+x=255;/1719pWork(nHeight*3/4-y-1)*nWidth+x=255;
11、break;/菱形case MODEFPHOTO:ReadImage(pImage,.fourier.bmp,nWidth,nHeight);break;default:break;void ReadImage(unsigned char *pImage,char *cFileName,int nWidth,int nHeight)int j;unsigned char *pWork;FILE *fp;if ( fp=fopen(cFileName,rb ) )/讀取一二進制文件fseek(fp,1078L,SEEK_SET);/,從文件開頭執(zhí)行,將指針移到1078位pWork=pImage+
12、(nHeight-1)*nWidth;/p指向image最后一行for ( j=0;jnHeight;j+,pWork-=nWidth )fread(pWork,nWidth,1,fp);fclose(fp);3、Reverse#include#define MODEGRAYBAR 0#define MODEGRAY 1#define MODEPHOTO1 2#define MODEPHOTO2 3#define MODEPHOTO3 4#define MODEPHOTO4 5#define MODEBLOCK 6#define MODEINCLINE 7#define MODEFPHOTO
13、8#define GRAYBARLEVEL 16 void ReadImage(unsigned char *pImage,char *cFileName,int nWidth,int nHeight);void InitImage(unsigned int nMode,unsigned char *pImage,int nWidth,int nHeight)int x,y,nWork,nWork1;unsigned char *pWork;int nPointx=nWidth/2;int nPointy=nHeight/2;float fWork;switch ( nMode )case M
14、ODEGRAYBAR:pWork=pImage; nWork=256/GRAYBARLEVEL; nWork1=nHeight/GRAYBARLEVEL;for ( y=0;ynHeight;y+ )for ( x=0;xnWidth;x+,pWork+ )(*pWork)=(y/nWork1)*nWork;break;/里面的灰度case MODEGRAY:pWork=pImage; nWork1=nHeight-nPointy; nWork=nWork1*nWork1;/(40,40)nWork1=nWidth-nPointx; nWork+=(nWork1*nWork1);/(40,32
15、00)nWork/=256;/12for ( y=0;ynHeight;y+ )for ( x=0;xnWidth;x+,pWork+ )nWork1=(x-nPointx)*(x-nPointx)+(y-nPointy)*(y-nPointy);nWork1=255-nWork1/nWork;/0到255之間的一個灰度的園,以圓象中心為圓心,255-nwork1/nwork為中心 if ( nWork1255 )nWork1=255;(*pWork)=nWork1;/ pWork=pImage;break;case MODEPHOTO1:ReadImage(pImage,.DSP.bmp,n
16、Width,nHeight);break;case MODEPHOTO2:ReadImage(pImage,.1.bmp,nWidth,nHeight);break;case MODEPHOTO3:ReadImage(pImage,.2.bmp,nWidth,nHeight);break;case MODEPHOTO4:ReadImage(pImage,.3.bmp,nWidth,nHeight);break;case MODEBLOCK:pWork=pImage;for ( y=0;ynHeight;y+ )for ( x=0;xnWidth;x+,pWork+ )(*pWork)=0;/全
17、黑pWork=pImage+(nHeight/4-1)*nWidth;for ( y=nHeight/4;ynHeight*3/4;y+,pWork+=nWidth )/20,60for ( x=nWidth/4;xnWidth*3/4;x+ )/20,60pWorkx=255;break;/白框case MODEINCLINE:pWork=pImage;for ( y=0;ynHeight;y+ )for ( x=0;xnWidth;x+,pWork+ )(*pWork)=0;/全黑pWork=pImage;fWork=nWidth/nHeight;for ( y=0;ynHeight/4;
18、y+ )for ( x=nWidth/2-fWork*y;xnWidth/2+fWork*y;x+ )pWork(y+nHeight/4)*nWidth+x=255;/1719pWork(nHeight*3/4-y-1)*nWidth+x=255;break;/菱形case MODEFPHOTO:ReadImage(pImage,.fourier.bmp,nWidth,nHeight);break;default:break;void ReadImage(unsigned char *pImage,char *cFileName,int nWidth,int nHeight)int j;uns
19、igned char *pWork;FILE *fp;if ( fp=fopen(cFileName,rb ) )/讀取一二進制文件fseek(fp,1078L,SEEK_SET);/,從文件開頭執(zhí)行,將指針移到1078位pWork=pImage+(nHeight-1)*nWidth;/p指向image最后一行for ( j=0;jnHeight;j+,pWork-=nWidth )fread(pWork,nWidth,1,fp);fclose(fp);實驗現(xiàn)象修改程序,實現(xiàn)圖像對比度增強#define IMAGEWIDTH 80#define IMAGEHEIGHT 80extern uns
20、igned char dbImageIMAGEWIDTH*IMAGEHEIGHT;extern unsigned char dbTargetImageIMAGEWIDTH*IMAGEHEIGHT;int mi,mj;unsigned int m_nWork;unsigned char *pImg,*pImg1;void Reverse(int nWidth,int nHeight)for ( mi=0;minWidth;mi+,pImg+,pImg1+ )if(*pImg)30)(*pImg1)=(unsigned char)(*pImg)*0.5);else if(*pImg)225)(*p
21、Img1)=(unsigned char)(1.15*(*pImg)-19);else (*pImg1)=(unsigned char)(0.5*(*pImg)+127);七、思考題1).圖像是如何讀入DSP內(nèi)存中的,數(shù)據(jù)形式是什么?答:fp為指針,通過fread(pWork,nWidth,1,fp);實現(xiàn)以一個nWidth的間隔從文件的最后一行逆序進行讀取數(shù)據(jù)。數(shù)據(jù)格式是二進制。2).數(shù)據(jù)存儲在什么位置?由什么決定?答:圖像存儲在以pWork為指針的內(nèi)存中,由圖像的pImage指針來制決定。八、心得體會通過此次DSP課程設(shè)計,我們對圖像處理有了基本的了解,將圖像按像素按位進行求反,可以得到類
22、似照相底片的效果。圖像求反后可以達到對原圖使黑變白,使白變黑的效果。修改圖像的程序,運用一個增強對比度的函數(shù),通過增加圖像中各部分間的反差,具體通過增加圖像中某兩個灰度間的動態(tài)范圍來實現(xiàn)。在較小灰度值的部分減小動態(tài)范圍,較大點的灰度值范圍的動態(tài)范圍增大,從而增加這個范圍內(nèi)的對比度。選擇不同的灰度值范圍進行合適的壓縮和增大動態(tài)范圍,就能得到不同的效果。這次設(shè)計中,我們深刻的認識到理論與實踐的差異,方到用時方恨少。做圖像增強的這一點時,起初想到用直方圖均衡化增強,但是使用時遇到了些困難,就放棄了,最終選擇使用增強對比度的灰度映射方法。起初是選擇幾個特殊點,做折線,改變灰度的動態(tài)范圍,達到增強對比度
23、的效果。其次是關(guān)于圖像讀取的一些問題,當(dāng)時一知半解,不太理解圖像時如何讀取的,以及存儲位置。后來我們商量之后,又請教了同學(xué),才得知圖像讀取時,采取逆序方式讀取,在將pImage的內(nèi)容傳給pWork。通過這次的合作,以及老師的知道,我們深刻看到了自己的不足之處,C語言的基礎(chǔ)真是堪憂,有必要在課余做到加強。其次,是本課程的學(xué)習(xí)與其他科目的綜合運用,不能僅僅停留在理論,還在于實踐。 附錄資料:不需要的可以自行刪除 Linux-c常用文件操作函數(shù)clearerr(清除文件流的錯誤旗標) 相關(guān)函數(shù) feof表頭文件 #include定義函數(shù) void clearerr(FILE * stream);函數(shù)
24、說明 clearerr()清除參數(shù)stream指定的文件流所使用的錯誤旗標。返回值 fclose(關(guān)閉文件) 相關(guān)函數(shù) close,fflush,fopen,setbuf表頭文件 #include定義函數(shù) int fclose(FILE * stream);函數(shù)說明 fclose()用來關(guān)閉先前fopen()打開的文件。此動作會讓緩沖區(qū)內(nèi)的數(shù)據(jù)寫入文件中,并釋放系統(tǒng)所提供的文件資源。返回值 若關(guān)文件動作成功則返回0,有錯誤發(fā)生時則返回EOF并把錯誤代碼存到errno。錯誤代碼 EBADF表示參數(shù)stream非已打開的文件。范例 請參考fopen()。 fdopen(將文件描述詞轉(zhuǎn)為文件指針)
25、相關(guān)函數(shù) fopen,open,fclose表頭文件 #include定義函數(shù) FILE * fdopen(int fildes,const char * mode);函數(shù)說明 fdopen()會將參數(shù)fildes 的文件描述詞,轉(zhuǎn)換為對應(yīng)的文件指針后返回。參數(shù)mode 字符串則代表著文件指針的流形態(tài),此形態(tài)必須和原先文件描述詞讀寫模式相同。關(guān)于mode 字符串格式請參考fopen()。返回值 轉(zhuǎn)換成功時返回指向該流的文件指針。失敗則返回NULL,并把錯誤代碼存在errno中。范例 #includemain()FILE * fp =fdopen(0,”w+”);fprintf(fp,”%sn”
26、,”hello!”);fclose(fp);執(zhí)行 hello! feof(檢查文件流是否讀到了文件尾) 相關(guān)函數(shù) fopen,fgetc,fgets,fread表頭文件 #include定義函數(shù) int feof(FILE * stream);函數(shù)說明 feof()用來偵測是否讀取到了文件尾,尾數(shù)stream為fopen()所返回之文件指針。如果已到文件尾則返回非零值,其他情況返回0。返回值 返回非零值代表已到達文件尾。 fflush(更新緩沖區(qū)) 相關(guān)函數(shù) write,fopen,fclose,setbuf表頭文件 #include定義函數(shù) int fflush(FILE* stream);
27、函數(shù)說明 fflush()會強迫將緩沖區(qū)內(nèi)的數(shù)據(jù)寫回參數(shù)stream指定的文件中。如果參數(shù)stream為NULL,fflush()會將所有打開的文件數(shù)據(jù)更新。返回值 成功返回0,失敗返回EOF,錯誤代碼存于errno中。錯誤代碼 EBADF 參數(shù)stream 指定的文件未被打開,或打開狀態(tài)為只讀。其它錯誤代碼參考write()。 fgetc(由文件中讀取一個字符) 相關(guān)函數(shù) open,fread,fscanf,getc表頭文件 include定義函數(shù) nt fgetc(FILE * stream);函數(shù)說明 fgetc()從參數(shù)stream所指的文件中讀取一個字符。若讀到文件尾而無數(shù)據(jù)時便返回
28、EOF。返回值 getc()會返回讀取到的字符,若返回EOF則表示到了文件尾。范例 #includemain()FILE *fp;int c;fp=fopen(“exist”,”r”);while(c=fgetc(fp)!=EOF)printf(“%c”,c);fclose(fp); fgets(由文件中讀取一字符串) 相關(guān)函數(shù) open,fread,fscanf,getc表頭文件 include定義函數(shù) har * fgets(char * s,int size,FILE * stream);函數(shù)說明 fgets()用來從參數(shù)stream所指的文件內(nèi)讀入字符并存到參數(shù)s所指的內(nèi)存空間,直到出
29、現(xiàn)換行字符、讀到文件尾或是已讀了size-1個字符為止,最后會加上NULL作為字符串結(jié)束。返回值 gets()若成功則返回s指針,返回NULL則表示有錯誤發(fā)生。范例 #includemain()char s80;fputs(fgets(s,80,stdin),stdout);執(zhí)行 this is a test /*輸入*/this is a test /*輸出*/ fileno(返回文件流所使用的文件描述詞) 相關(guān)函數(shù) open,fopen表頭文件 #include定義函數(shù) int fileno(FILE * stream);函數(shù)說明 fileno()用來取得參數(shù)stream指定的文件流所使用
30、的文件描述詞。返回值 返回文件描述詞。范例 #includemain()FILE * fp;int fd;fp=fopen(“/etc/passwd”,”r”);fd=fileno(fp);printf(“fd=%dn”,fd);fclose(fp);執(zhí)行 fd=3 fopen(打開文件) 相關(guān)函數(shù) open,fclose表頭文件 #include定義函數(shù) FILE * fopen(const char * path,const char * mode);函數(shù)說明 參數(shù)path字符串包含欲打開的文件路徑及文件名,參數(shù)mode字符串則代表著流形態(tài)。mode有下列幾種形態(tài)字符串:r 打開只讀文件,
31、該文件必須存在。r+ 打開可讀寫的文件,該文件必須存在。w 打開只寫文件,若文件存在則文件長度清為0,即該文件內(nèi)容會消失。若文件不存在則建立該文件。w+ 打開可讀寫文件,若文件存在則文件長度清為零,即該文件內(nèi)容會消失。若文件不存在則建立該文件。a 以附加的方式打開只寫文件。若文件不存在,則會建立該文件,如果文件存在,寫入的數(shù)據(jù)會被加到文件尾,即文件原先的內(nèi)容會被保留。a+ 以附加方式打開可讀寫的文件。若文件不存在,則會建立該文件,如果文件存在,寫入的數(shù)據(jù)會被加到文件尾后,即文件原先的內(nèi)容會被保留。上述的形態(tài)字符串都可以再加一個b字符,如rb、w+b或ab等組合,加入b 字符用來告訴函數(shù)庫打開的
32、文件為二進制文件,而非純文字文件。不過在POSIX系統(tǒng),包含Linux都會忽略該字符。由fopen()所建立的新文件會具有S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH(0666)權(quán)限,此文件權(quán)限也會參考umask值。返回值 文件順利打開后,指向該流的文件指針就會被返回。若果文件打開失敗則返回NULL,并把錯誤代碼存在errno 中。附加說明 一般而言,開文件后會作一些文件讀取或?qū)懭氲膭幼鳎糸_文件失敗,接下來的讀寫動作也無法順利進行,所以在fopen()后請作錯誤判斷及處理。范例 #includemain()FILE * fp;fp=fopen
33、(“noexist”,”a+”);if(fp= =NULL) return;fclose(fp); fputc(將一指定字符寫入文件流中) 相關(guān)函數(shù) fopen,fwrite,fscanf,putc表頭文件 #include定義函數(shù) int fputc(int c,FILE * stream);函數(shù)說明 fputc 會將參數(shù)c 轉(zhuǎn)為unsigned char 后寫入?yún)?shù)stream 指定的文件中。返回值 fputc()會返回寫入成功的字符,即參數(shù)c。若返回EOF則代表寫入失敗。范例 #includemain()FILE * fp;char a26=”abcdefghijklmnopqrstuv
34、wxyz”;int i;fp= fopen(“noexist”,”w”);for(i=0;i26;i+)fputc(ai,fp);fclose(fp); fputs(將一指定的字符串寫入文件內(nèi)) 相關(guān)函數(shù) fopen,fwrite,fscanf,fputc,putc表頭文件 #include定義函數(shù) int fputs(const char * s,FILE * stream);函數(shù)說明 fputs()用來將參數(shù)s所指的字符串寫入到參數(shù)stream所指的文件內(nèi)。返回值 若成功則返回寫出的字符個數(shù),返回EOF則表示有錯誤發(fā)生。范例 請參考fgets()。 fread(從文件流讀取數(shù)據(jù)) 相關(guān)函數(shù)
35、 fopen,fwrite,fseek,fscanf表頭文件 #include定義函數(shù) size_t fread(void * ptr,size_t size,size_t nmemb,FILE * stream);函數(shù)說明 fread()用來從文件流中讀取數(shù)據(jù)。參數(shù)stream為已打開的文件指針,參數(shù)ptr 指向欲存放讀取進來的數(shù)據(jù)空間,讀取的字符數(shù)以參數(shù)size*nmemb來決定。Fread()會返回實際讀取到的nmemb數(shù)目,如果此值比參數(shù)nmemb 來得小,則代表可能讀到了文件尾或有錯誤發(fā)生,這時必須用feof()或ferror()來決定發(fā)生什么情況。返回值 返回實際讀取到的nmemb
36、數(shù)目。附加說明 范例 #include#define nmemb 3struct testchar name20;int size;snmemb;main()FILE * stream;int i;stream = fopen(“/tmp/fwrite”,”r”);fread(s,sizeof(struct test),nmemb,stream);fclose(stream);for(i=0;inmemb;i+)printf(“name%d=%-20s:size%d=%dn”,i,,i,si.size);執(zhí)行 name0=Linux! size0=6name1=FreeBSD!
37、size1=8name2=Windows2000 size2=11 freopen(打開文件) 相關(guān)函數(shù) fopen,fclose表頭文件 #include定義函數(shù) FILE * freopen(const char * path,const char * mode,FILE * stream);函數(shù)說明 參數(shù)path字符串包含欲打開的文件路徑及文件名,參數(shù)mode請參考fopen()說明。參數(shù)stream為已打開的文件指針。Freopen()會將原stream所打開的文件流關(guān)閉,然后打開參數(shù)path的文件。返回值 文件順利打開后,指向該流的文件指針就會被返回。如果文件打開失敗則返回NULL,
38、并把錯誤代碼存在errno 中。范例 #includemain()FILE * fp;fp=fopen(“/etc/passwd”,”r”);fp=freopen(“/etc/group”,”r”,fp);fclose(fp); fseek(移動文件流的讀寫位置) 相關(guān)函數(shù) rewind,ftell,fgetpos,fsetpos,lseek表頭文件 #include定義函數(shù) int fseek(FILE * stream,long offset,int whence);函數(shù)說明 fseek()用來移動文件流的讀寫位置。參數(shù)stream為已打開的文件指針,參數(shù)offset為根據(jù)參數(shù)whence
39、來移動讀寫位置的位移數(shù)。參數(shù) whence為下列其中一種:SEEK_SET從距文件開頭offset位移量為新的讀寫位置。SEEK_CUR 以目前的讀寫位置往后增加offset個位移量。SEEK_END將讀寫位置指向文件尾后再增加offset個位移量。當(dāng)whence值為SEEK_CUR 或SEEK_END時,參數(shù)offset允許負值的出現(xiàn)。下列是較特別的使用方式:1) 欲將讀寫位置移動到文件開頭時:fseek(FILE *stream,0,SEEK_SET);2) 欲將讀寫位置移動到文件尾時:fseek(FILE *stream,0,0SEEK_END);返回值 當(dāng)調(diào)用成功時則返回0,若有錯誤則
40、返回-1,errno會存放錯誤代碼。附加說明 fseek()不像lseek()會返回讀寫位置,因此必須使用ftell()來取得目前讀寫的位置。范例 #includemain()FILE * stream;long offset;fpos_t pos;stream=fopen(“/etc/passwd”,”r”);fseek(stream,5,SEEK_SET);printf(“offset=%dn”,ftell(stream);rewind(stream);fgetpos(stream,&pos);printf(“offset=%dn”,pos);pos=10;fsetpos(stream,&
41、pos);printf(“offset = %dn”,ftell(stream);fclose(stream);執(zhí)行 offset = 5offset =0offset=10 ftell(取得文件流的讀取位置) 相關(guān)函數(shù) fseek,rewind,fgetpos,fsetpos表頭文件 #include定義函數(shù) long ftell(FILE * stream);函數(shù)說明 ftell()用來取得文件流目前的讀寫位置。參數(shù)stream為已打開的文件指針。返回值 當(dāng)調(diào)用成功時則返回目前的讀寫位置,若有錯誤則返回-1,errno會存放錯誤代碼。錯誤代碼 EBADF 參數(shù)stream無效或可移動讀寫位
42、置的文件流。范例 參考fseek()。 fwrite(將數(shù)據(jù)寫至文件流) 相關(guān)函數(shù) fopen,fread,fseek,fscanf表頭文件 #include定義函數(shù) size_t fwrite(const void * ptr,size_t size,size_t nmemb,FILE * stream);函數(shù)說明 fwrite()用來將數(shù)據(jù)寫入文件流中。參數(shù)stream為已打開的文件指針,參數(shù)ptr 指向欲寫入的數(shù)據(jù)地址,總共寫入的字符數(shù)以參數(shù)size*nmemb來決定。Fwrite()會返回實際寫入的nmemb數(shù)目。返回值 返回實際寫入的nmemb數(shù)目。范例 #include#defin
43、e set_s (x,y) strcoy(,y);sx.size=strlen(y);#define nmemb 3struct testchar name20;int size;snmemb;main()FILE * stream;set_s(0,”Linux!”);set_s(1,”FreeBSD!”);set_s(2,”Windows2000.”);stream=fopen(“/tmp/fwrite”,”w”);fwrite(s,sizeof(struct test),nmemb,stream);fclose(stream);執(zhí)行 參考fread()。 getc(由文件中讀
44、取一個字符) 相關(guān)函數(shù) read,fopen,fread,fgetc表頭文件 #include定義函數(shù) int getc(FILE * stream);函數(shù)說明 getc()用來從參數(shù)stream所指的文件中讀取一個字符。若讀到文件尾而無數(shù)據(jù)時便返回EOF。雖然getc()與fgetc()作用相同,但getc()為宏定義,非真正的函數(shù)調(diào)用。返回值 getc()會返回讀取到的字符,若返回EOF則表示到了文件尾。范例 參考fgetc()。 getchar(由標準輸入設(shè)備內(nèi)讀進一字符) 相關(guān)函數(shù) fopen,fread,fscanf,getc表頭文件 #include定義函數(shù) int getchar
45、(void);函數(shù)說明 getchar()用來從標準輸入設(shè)備中讀取一個字符。然后將該字符從unsigned char轉(zhuǎn)換成int后返回。返回值 getchar()會返回讀取到的字符,若返回EOF則表示有錯誤發(fā)生。附加說明 getchar()非真正函數(shù),而是getc(stdin)宏定義。范例 #includemain()FILE * fp;int c,i;for(i=0li5;i+)c=getchar();putchar(c);執(zhí)行 1234 /*輸入*/1234 /*輸出*/ gets(由標準輸入設(shè)備內(nèi)讀進一字符串) 相關(guān)函數(shù) fopen,fread,fscanf,fgets表頭文件 #inc
46、lude定義函數(shù) char * gets(char *s);函數(shù)說明 gets()用來從標準設(shè)備讀入字符并存到參數(shù)s所指的內(nèi)存空間,直到出現(xiàn)換行字符或讀到文件尾為止,最后加上NULL作為字符串結(jié)束。返回值 gets()若成功則返回s指針,返回NULL則表示有錯誤發(fā)生。附加說明 由于gets()無法知道字符串s的大小,必須遇到換行字符或文件尾才會結(jié)束輸入,因此容易造成緩沖溢出的安全性問題。建議使用fgets()取代。范例 參考fgets() mktemp(產(chǎn)生唯一的臨時文件名) 相關(guān)函數(shù) tmpfile表頭文件 #include定義函數(shù) char * mktemp(char * template
47、);函數(shù)說明 mktemp()用來產(chǎn)生唯一的臨時文件名。參數(shù)template所指的文件名稱字符串中最后六個字符必須是XXXXXX。產(chǎn)生后的文件名會借字符串指針返回。返回值 文件順利打開后,指向該流的文件指針就會被返回。如果文件打開失敗則返回NULL,并把錯誤代碼存在errno中。附加說明 參數(shù)template所指的文件名稱字符串必須聲明為數(shù)組,如:char template =”template-XXXXXX”;不可用char * template=”template-XXXXXX”;范例 #includemain()char template =”template-XXXXXX”;mktemp(template);printf(“template=%sn”,template); putc(將一指定字符寫入文件中) 相關(guān)函數(shù) fopen,fwrite,fscanf,fputc表頭文件 #include定義函數(shù) int putc(int c,FILE * stream);函數(shù)說明 putc()會將參數(shù)c轉(zhuǎn)為unsigned char后寫入?yún)?shù)stream指定的文件中。雖然putc()與fputc()作用相同,但putc()為宏定義,非真正的函數(shù)調(diào)用。返回值 putc()會返回寫入成功的字符,即參數(shù)c。若返回EOF則代表寫入失敗。范例 參考fputc(
溫馨提示
- 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)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 腫瘤病人心理護理措施
- “春蕾綻放·守護成長”青春期女生健康教育講座大綱
- 西安健康工程職業(yè)學(xué)院《法醫(yī)人類學(xué)》2023-2024學(xué)年第一學(xué)期期末試卷
- 湖北交通職業(yè)技術(shù)學(xué)院《中西醫(yī)結(jié)合婦科學(xué)》2023-2024學(xué)年第一學(xué)期期末試卷
- 上海體育大學(xué)《中外舞蹈史(二)》2023-2024學(xué)年第一學(xué)期期末試卷
- 溫州理工學(xué)院《寧夏文旅專題》2023-2024學(xué)年第一學(xué)期期末試卷
- 微信社交影響模式-洞察及研究
- 腫瘤疼痛案例分享
- 生態(tài)工程措施在江河水環(huán)境治理中的應(yīng)用
- 全球化背景下戰(zhàn)略關(guān)鍵領(lǐng)域拔尖創(chuàng)新人才需求變化
- 2025屆四川成都錦江區(qū)數(shù)學(xué)七下期末質(zhì)量檢測試題含解析
- 無人機飛行器結(jié)構(gòu)與性能試題及答案
- 南京二模 南京市2025屆高三年級第二次模擬考試 數(shù)學(xué)試卷
- 廣東深圳2025年公開招聘農(nóng)村(村務(wù))工作者筆試題帶答案分析
- 《蔚來汽車》課件
- 建筑工地安全應(yīng)急預(yù)案
- 《義務(wù)教育生物課程標準(2022年版)》解讀
- 膝關(guān)節(jié)滑膜炎試題及答案
- 2025年白芷種植市場調(diào)研報告
- 全國行政區(qū)域身份證代碼表(電子表格版)
- 期末復(fù)習(xí)人教PEP版英語五年級下冊
評論
0/150
提交評論