c語言中a2
『壹』 c語言中,是否可以調用其它文件的函數
可以調用。
一、從一個源文件里調用另一個源文件的函數。在源文件A1.c中調用A2.c 中的函數有兩種方法:
1、在A2.c中有完整的函數定義,在A1.c中添加一下要用到的函數原型(聲明)就可以了,例如:
在A2.c中:有函數void A2(){...};。
在A1.c中:在文件前頭增加一行:void A2();就可以了。
2、把A2.c中完整定義的函數的原型,寫到一個A2.h文件中,然後在A1.c的文件頭增加#include "A2.h"就可以了。
以上兩種方法,在A1.c中都可以正常的調用,就跟在A2.c中調用一樣。
其實函數默認是外部的,只要在其他文件中聲明就能使用;但是注意如果在前面加上static,就只能在本文件中使用了,不能再被其他的文件調用。
二、編寫頭文件:
1、一個.h文件要 對應有一個.c文件,這樣鏈接器就可以調用這個文件里的函數。比如a.h 和 a.c。
在.h文件中:
#ifndef __A_H_
#define __A_H_
#include<stdio.h>
void trans2(double B) ;
double trans1() ;
#endif
2、把相應的函數定義寫在.c文件中。這里要強調一點:要加上#include ".h",這個一般作為一種工程規范。因為如果.c文件中的函數也需要調用同個.c中的其它函數,那麼這個.
c往往會include對應的.h,這樣就不需要為聲明和調用順序而發愁了。比如頭文件里進行了變數的聲明,這個時候對應的.c文件是一定要加上這個頭文件的。
3、再在其他的main.c文件開頭添加#include "a.h"。
(1)c語言中a2擴展閱讀:
include用法:
#include命令預處理命令的一種,預處理命令可以將別的源代碼內容插入到所指定的位置;可以標識出只有在特定條件下才會被編譯的某一段程序代碼;可以定義類似標識符功能的宏,在編譯時,預處理器會用別的文本取代該宏。
插入頭文件的內容
#include命令告訴預處理器將指定頭文件的內容插入到預處理器命令的相應位置。有兩種方式可以指定插入頭文件:
1、#include<文件名>
2、#include"文件名"
如果需要包含標准庫頭文件或者實現版本所提供的頭文件,應該使用第一種格式。如下例所示:
#include<math.h>//一些數學函數的原型,以及相關的類型和宏
如果需要包含針對程序所開發的源文件,則應該使用第二種格式。
採用#include命令所插入的文件,通常文件擴展名是.h,文件包括函數原型、宏定義和類型定義。只要使用#include命令,這些定義就可被任何源文件使用。
『貳』 c語言中,a 和a[] 有什麼區別
a[]比a少一維,我具體給你解釋下。
幾個元素可以組成數組,而幾個一維數組可以組成二維數組,如此一直增加維數。
比如說a[0]=2,a[1]=1,a[2]=3,組成一個一維數組,這就是a.但是,你要注意,a不是直接把這些東西都存著的,a只存首地址。
假設定義了一個二維數組a[3][3].這時候a[0],a[1],a[2]就不再是元素了,而代表的是一個有三個元素的一位數組,而此時的a就是一個二維數組。如果感覺這個有點困難沒關系,等學習了指針什麼的久很好理解這個了。
再說說你給的程序,你是不是在疑問為什麼gets()直接給str1 就可以了?還有那個輸出函數,為啥只用給str1就可以?
這得給存儲方式有關,字元串就是字元的二維數組,gets()需要輸入字元串的首地址,這個還算好理解,因為你應該學過了scanf()了,二者差不多,關鍵是為什麼輸出函數直接就寫了str1呢?printf()之前你學的一般都是(printf("%d",a[1]));這種類型的。這里為啥要填一個地址參數呢?這是因為你前面是%s s代表字元串,字元串本身就是二維的,因此,你當然不能只給他一個單獨的元素了,那麼,你給了首地址他如何知道你這個字元串是啥呢?因為字元串都是順序存儲的,更重要的是字元串在結尾處有個標志「/0」,因此,你只要給力他首地址,他就知道從哪裡開始,從哪裡結束了。
純手打,望採納。