c語言函數的使用
『壹』 c語言中函數的作用
C語言中的函數的作用是可以將一段經常需要使用的代碼封裝起來,在需要使用時可以直接調用。
示例:
語言的函數定義和函數聲明
#include<stdio.h>
//使用函數前,需要在main函數前對使用的函數進行聲明
int getMax(int, int);
void main() {
int t=getMax(12, 21);
printf("%d ", t);
getchar();
}
int getMax(int a, int b) {
if (a > b) {
return a;
}
else {
return b;
}
}
(1)c語言函數的使用擴展閱讀
scanf 函數
函數原型:int scanf(char *format [,argument,...])
功能:從標准輸入設備(一般指鍵盤)實現格式化輸入
返回值:成功返回讀入的數據項個數
函數參數:format 格式化字元串
argument 輸入數據項的地址列表
常用格式類型參考printf函數的個格式類型
用法舉例:
從標准輸入設備中輸入一個整數到整形變數a中,輸入一個浮點數到浮點型變數b中
int a=0;
float b=0;
scanf("%d%f",&a,&b);
上面程序執行後,從鍵盤輸入: 19 18.6 ,程序將 19賦值給變數a, 18.6賦值給變數b 。
『貳』 C語言如何調用函數
C語言中,函數調用的一般形式為:
函數名(實際參數表)
對無參函數調用時則無實際參數表。實際參數表中的參數可以是常數、變數或其它構造類型數據及表達式。各實參之間用逗號分隔。
#include<stdio.h>
intfun(intx,inty);//函數聲明,如果函數寫在被調用處之前,可以不用聲明
voidmain()
{
inta=1,b=2,c;
c=fun(a,b);//函數的調用,調用自定義函數fun,其中a,b為實際參數,傳遞給被調用函數的輸入值
}
//自定義函數fun
intfun(intx,inty)//函數首部
{//{}中的語言為函數體
returnx>y?x:y;//返回x和y中較大的一個數
}
(2)c語言函數的使用擴展閱讀
C語言中不允許作嵌套的函數定義。因此各函數之間是平行的,不存在上一級函數和下一級函數的問題。但是C語言允許在一個函數的定義中出現對另一個函數的調用。
這樣就出現了函數的嵌套調用。即在被調函數中又調用其它函數。這與其它語言的子程序嵌套的情形是類似的。其關系可表示如圖。
圖表示了兩層嵌套的情形。其執行過程是:執行main函數中調用a函數的語句時,即轉去執行a函數,在a函數中調用b 函數時,又轉去執行b函數,b函數執行完畢返回a函數的斷點繼續執行,a函數執行完畢返回main函數的斷點繼續執行。
『叄』 c語言定義函數是什麼
c語言定義函數是一段可以重復使用的代碼,用來獨立地完成某個功能,它可以接收用戶傳遞的數據,也可以不接收。
接收用戶數據的函數在定義時要指明參數,不接收用戶數據的不需要指明,根據這一點可以將函數分為有參函數和無參函數。
函數就是一段封裝好的,可以重復使用的代碼,它使得我們的程序更加模塊化,不需要編寫大量重復的代碼。函數可以提前保存起來,並給它起一個獨一無二的名字,只要知道它的名字就能使用這段代碼。
C語言特點及運用范圍:
C語言是一門面向過程的、抽象化的通用程序設計語言,廣泛應用於底層開發。C語言能以簡易的方式編譯、處理低級存儲器。C語言是僅產生少量的機器語言以及不需要任何運行環境支持便能運行的高效率程序設計語言。它既具有高級語言的特點,又具有匯編語言的特點。
C語言特點:簡潔的語言、具有結構化的控制語句、豐富的數據類型、豐富的運算符、可對物理地址進行直接操作、代碼具有較好的可移植性、可生成高質量、目標代碼執行效率高的程序。
C語言是一門面向過程的計算機編程語言,C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲器、僅產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語言。C語言描述問題比匯編語言迅速、工作量小、可讀性好、易於調試、修改和移植,而代碼質量與匯編語言相當。
『肆』 c語言 自定義函數怎麼用啊
自定義函數是由用戶按需要寫的函數。這與庫函數相對應的,庫函數是由c系統提供的函數,已經定義好了如printf
、
scanf
、
getchar
、putchar、gets、puts、strcat等函數均屬此類。
說白了,自定義函數是是自己寫的,想實現什麼功能就寫什麼,然後在用的時候和庫函數(系統定義的)的一樣調用就是了,相當於自己增加了一個自己的庫函數。
『伍』 C語言中函數是怎樣用的
定義好的函數,若在主函數之後定義,在主函數中要聲明一下。
聲明方法為把定義好的函數按原樣寫下,再加上一個「;」。
若在主函數之前定義,在主函數就可以直接調用。
一般格式k=函數名(變數);
函數運算結果通過return語句返回,賦值給k。
希望你能看懂!
『陸』 c語言 函數的使用
搞個登錄函數吧,成功返回0,否則返回-1
#include "stdio.h"
#include "conio.h"
#include "string.h"
int Login()
{ char a[40],b[40],d[40];
int c=0,rt=(-1);
while ( c<5 )
{
clrscr();
printf("Please input your QQ num: "); scanf("%s",a);
printf("Please input your password: "); scanf("%s",b);
clrscr();
printf("****************************************\n");
printf("This is your number and passwrod:\n");
printf("****************************************\n");
printf("* number: %s *\n",a);
printf("* password: %s *\n",b);
printf("****************************************\n");
printf("Please enter any key and press enter to determine.\n");
scanf("%s",d);
if ( strcmp(a,"1456680570")==0 )
{ if ( strcpm(b,"canfeng")==0 )
{
printf("Login success!\n"); rt=0; break;
} else printf("Password error!\n");
} else printf("Account error!\n");
c++;
}
}
void main()
{
if ( Login()==0 ) { .... }
}
『柒』 C語言中malloc函數的使用方法
C語言中malloc是動態內存分配函數。
函數原型:void *malloc(unsigned int num_bytes);
參數:num_bytes 是無符號整型,用於表示分配的位元組數。
返回值:如果分配成功則返回指向被分配內存的指針(此存儲區中的初始值不確定),否則返回空指針NULL。void* 表示未確定類型的指針,void *可以指向任何類型的數據,更明確的說是指申請內存空間時還不知道用戶是用這段空間來存儲什麼類型的數據(比如是char還是int或者...)
功能:分配長度為num_bytes位元組的內存塊
注意:當內存不再使用時,應使用free()函數將內存塊釋放。函數返回的指針一定要適當對齊,使其可以用於任何數據對象。關於該函數的原型,在以前malloc返回的是char型指針,新的ANSIC標准規定,該函數返回為void型指針,因此必要時要進行類型轉換。
實例:
#include"stdio.h"
#include"malloc.h"//malloc()函數被包含在malloc.h裡面
int main(void)
{
char*a=NULL;//聲明一個指向a的char*類型的指針
a=(char*)malloc(100*sizeof(char));//使用malloc分配內存的首地址,然後賦值給a
if(!a)//如果malloc失敗,可以得到一些log
{
perror("malloc");
return-1;
}
sprintf(a,"%s","HelloWorld\n");//"HelloWorld\n"寫入a指向的地址
printf("%s\n",a);//輸出用戶輸入的數據
free(a);//釋放掉使用的內存地址
return0;//例2有無內存泄露?
}
『捌』 C語言中的POW函數怎麼使用
pow()函數用來求x的y次冪,x、y及函數值都是double型 ,其原型為:double pow(double x, double y)。
實例代碼如下:
#include<stdio.h>
#include<math.h>
void main()
{
double x = 2, y = 10;
printf("%f ",pow(x, y));
return 0;
}
(8)c語言函數的使用擴展閱讀:
在調用pow函數時,可能導致錯誤的情況:
如果底數 x 為負數並且指數 y 不是整數,將會導致 domain error錯誤。
如果底數 x 和指數 y 都是 0,可能會導致 domain error?錯誤,也可能沒有;這跟庫的實現有關。
如果底數 x 是 0,指數 y 是負數,可能會導致?domain error 或pole error 錯誤,也可能沒有;這跟庫的實現有關。
如果返回值 ret 太大或者太小,將會導致range error 錯誤。
錯誤代碼:
如果發生 domain error 錯誤,那麼全局變數 errno 將被設置為 EDOM;
如果發生 pole error 或 range error 錯誤,那麼全局變數 errno 將被設置為 ERANGE。
『玖』 c語言編程,函數如何用