c語言函數內聯
1. 在c語言中內聯函數有什麼作用
1.內聯函數可減少cpu的系統開銷,並且程序的整體速度將加快,但當內聯函數很大時,會有相反的作用,因此一般比較小的函數才使用內聯函數.
2.有兩種內聯函數的聲明方法,一種是在函數前使用inline關見字,另一種是在類的內部定義函數的代碼,這樣的函數將自動轉換為內聯函數,而且沒必要將inline放在函數前面.
3.內聯是一種對編譯器的請求,下面這些情況會阻止編譯器服從這項請求.
如果函數中包含有循環,switch或goto語句,遞歸函數,含有static的函數.
由此可以看出,內聯函數和成員函數沒什麼區別,區別就在於怎樣加快函數的執行速度而已。
2. C++內聯函數在 在編譯時是將該函數的目標代碼插入每個調用該函數的地方
內聯函數在調用時,是將調用表達式用內聯函數體來替換,而一般函數進行調用時,要將程序執行權轉到被調用函數中,然後再返回到調用它的函數中。
如果內聯失敗這個函數就是一個普通的函數,普通的函數不會被編譯器展開,只是作為函數調用。內聯函數比普通函數效率高的原因就是編譯器在調用處把這個函數展開,展開就是直接執行代碼而不是調用這個函數,像宏展開的意思。
(2)c語言函數內聯擴展閱讀:
宏調用並不執行類型檢查,甚至連正常參數也不檢查,但是函數調用卻要檢查。C語言的宏使用的是文本替換,可能導致無法預料的後果,因為需要重新計算參數和操作順序。在宏中的編譯錯誤很難發現,因為它們引用的是擴展的代碼,而不是程序員鍵入的。
許多結構體使用宏或者使用不同的語法來表達很難理解。內聯函數使用與普通函數相同的語言,可以隨意的內聯和不內聯。
3. C語言中 內聯函數的速度快於普通函數,普通函數存在的作用是為什麼不都用內聯函數代替
速度是有代價的,inline和宏都是用空間換時間。
使用內聯函數的時候要注意:
1.遞歸函數不能定義為內聯函數
2.內聯函數一般適合於不存在while和switch等復雜的結構且只有1~5條語句的小函數上,否則編譯系統將該函數視為普通函數。
3.內聯函數只能先定義後使用,否則編譯系統也會把它認為是普通函數。
4.對內聯函數不能進行異常的介面聲明。
4. 關於C語言,內聯函數有什麼優點
引入內聯函數的目的是為了解決程序中函數調用的效率問題。
函數是一種更高級的抽象。它的引入使得編程者只關心函數的功能和使用方法,而不必關心函數功能的具體實現;函數的引入可以減少程序的目標代碼,實現程序代碼和數據的共享。但是,函數調用也會帶來降低效率的問題,因為調用函數實際上將程序執行順序轉移到函數所存放在內存中某個地址,將函數的程序內容執行完後,再返回到轉去執行該函數前的地方。這種轉移操作要求在轉去前要保護現場並記憶執行的地址,轉回後先要恢復現場,並按原來保存地址繼續執行。因此,函數調用要有一定的時間和空間方面的開銷,於是將影響其效率。特別是對於一些函數體代碼不是很大,但又頻繁地被調用的函數來講,解決其效率問題更為重要。引入內聯函數實際上就是為了解決這一問題。
在程序編譯時,編譯器將程序中出現的內聯函數的調用表達式用內聯函數的函數體來進行替換。顯然,這種做法不會產生轉去轉回的問題,但是由於在編譯時將函數休中的代碼被替代到程序中,因此會增加目標程序代碼量,進而增加空間開銷,而在時間代銷上不象函數調用時那麼大,可見它是以目標代碼的增加為代價來換取時間的節省。
5. C語言的宏定義和C++的內聯函數有什麼意義
提高效率。
這個是主要意義。
要知道
調用一個函數,是需要時間的
而且 耗費不是太小。
在要求效率比較高的情況下,使用宏 或者內聯,可以使代碼清爽的同時,不降低效率。
6. C語言中有內聯函數么
應該是c++中才有的,
inline 關鍵字用來定義一個類的內聯函數,引入它的主要原因是用它替代C中表達式形式的宏定義。
表達式形式的宏定義一例:
#define ExpressionName(Var1,Var2) (Var1+Var2)*(Var1-Var2)
為什麼要取代這種形式呢,且聽我道來:
1.
首先談一下在C中使用這種形式宏定義的原因,C語言是一個效率很高的語言,這種宏定義在形式及使用上像一個函數,但它使用預處理器實現,沒有了參數壓棧,代碼生成等一系列的操作,因此,效率很高,這是它在C中被使用的一個主要原因。
2.
這種宏定義在形式上類似於一個函數,但在使用它時,僅僅只是做預處理器符號表中的簡單替換,因此它不能進行參數有效性的檢測,也就不能享受C++編譯器嚴格類型檢查的好處,另外它的返回值也不能被強制轉換為可轉換的合適的類型,這樣,它的使用就存在著一系列的隱患和局限性。
3.
在C++中引入了類及類的訪問控制,這樣,如果一個操作或者說一個表達式涉及到類的保護成員或私有成員,你就不可能使用這種宏定義來實現(因為無法將this指針放在合適的位置)。
4. inline 推出的目的,也正是為了取代這種表達式形式的宏定義,它消除了它的缺點,同時又很好地繼承了它的優點。
為什麼inline能很好地取代表達式形式的預定義呢?
對應於上面的1-3點,闡述如下:
1. inline 定義的類的內聯函數,函數的代碼被放入符號表中,在使用時直接進行替換,(像宏一樣展開),沒有了調用的開銷,效率也很高。
2.
很明顯,類的內聯函數也是一個真正的函數,編譯器在調用一個內聯函數時,會首先檢查它的參數的類型,保證調用正確。然後進行一系列的相關檢查,就像對待任何一個真正的函數一樣。這樣就消除了它的隱患和局限性。
3. inline 可以作為某個類的成員函數,當然就可以在其中使用所在類的保護成員及私有成員。
在何時使用inline函數:
首先,你可以使用inline函數完全取代表達式形式的宏定義。
另外要注意,內聯函數一般只會用在函數內容非常簡單的時候,這是因為,內聯函數的代碼會在任何調用它的地方展開,如果函數太復雜,代碼膨脹帶來的惡果很可能會大於效率的提高帶來的益處。
7. 求助!!關於C++中內聯函數的一些問題
在類中定義的成員函數全部默認為內聯函數。可以顯示加上 inline 標識符。或者不加
在類中聲明的成員函數,如果沒加inline。則在類外定義該成員函數時加了inline,該成員函數也為內聯函數。
反正不管是聲明還是定義,只要看見有 inline ,都為內聯
存在的意思
#include <iostream>
using namespace std;
int main()
{
cout<<print();
return 0;
}
int print(){return 1;}
你就找不到定義了
8. C語言有內聯函數這個概念嗎
其實看你用得編譯器了,如果你用的VC++6.0的話, 不管是.C文件還是.CPP文件都可以用inline 定義內聯函數。但是語法來說,C語言是沒有內聯這個概念的,C++才有
9. C語言內聯函數相關小問題
C語言編譯器應該不支持inline
inline 關鍵字用來定義一個類的內聯函數,C++引入它的主要原因是用它替代C中表達式形式的宏定義
10. 關於C語言內聯函數
C語言本身是不支持內聯函數的,在最新的C標准C99中C語言支持了內聯函數。
C++支持內聯函數。
從編譯器的角度:
有些C語言編譯器,例如GNU C提供了內聯函數的支持。
所有C++編譯器都支持內聯函數。
如果你的C語言編譯器不支持內聯函數,看看它有多古老,太古老不行(例如 Turbo C 2.0)。如果是C/C++合體編譯器,那就切換到編譯C++模式(例如VisualC++)。