成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

C++內聯函數給我們帶來哪些幫助

開發 后端
C++內聯函數的作用比較強大,不但能夠去除函數調用時所引起的效率負擔,而且還能幫助我們保留下一般函數的優點。

C++編程語言中還是有很多比較重要的函數在實際編程中起著比較大的作用。比如我們今天為大家介紹的C++內聯函數,就是一個應用頻繁,功能強大的函數。那么就讓么我們一起來看看它的一些基本概念吧。#t#

C++內聯函數既能夠去除函數調用所帶來的效率負擔又能夠保留一般函數的優點。然而,內聯函數并不是***藥,在一些情況下,它甚至能夠降低程序的性能。因此在使用的時候應該慎重。

1.我們先來看看內聯函數給我們帶來的好處:從一個用戶的角度來看,內聯函數看起來和普通函數一樣,它可以有參數和返回值,也可以有自己的作用域,然而它卻不會引入一般函數調用所帶來的負擔。另外,它可以比宏更安全更容易調試。

當然有一點應該意識到,inline specifier僅僅是對編譯器的建議,編譯器有權利忽略這個建議。那么編譯器是如何決定函數內聯與否呢?一般情況下關鍵性因素包括函數體的大小,是否有局部對象被聲明,函數的復雜性等等。

2.那么如果一個函數被聲明為inline但是卻沒有被內聯將會發生什么呢?理論上,當編譯器拒絕內聯一個函數的時候,那個函數會像普通函數一樣被對待,但是還會出現一些其他的問題。例如下面這段代碼:

  1. // filename Time.h   
  2. #include< ctime>   
  3. #include< iostream>   
  4. using namespace std;   
  5. class Time   
  6. {   
  7. public:   
  8. inline void Show() { for (int i = 0; i< 10; i++) 
    cout
    < < time(0)< < endl;}   
  9. }; 

因為成員函數Time::Show()包括一個局部變量和一個for循環,所以編譯器一般拒絕inline,并且把它當作一個普通的成員函數。但是這個包含類聲明的頭文件會被單獨的#include進各個獨立的編譯單元中:

  1. // filename f1.cpp   
  2. #include "Time.hj"   
  3. void f1()   
  4. {   
  5. Time t1;   
  6. t1.Show();   
  7. }   
  8. // filename f2.cpp   
  9. #include "Time.h"   
  10. void f2()   
  11. {   
  12. Time t2;   
  13. t2.Show();   

結果編譯器為這個程序生成了兩個相同成員函數的拷貝:

  1. void f1();   
  2. void f2();   
  3. int main()   
  4. {   
  5. f1();   
  6. f2();   
  7. return 0;   

當程序被鏈接的時候,linker將會面對兩個相同的Time::Show()拷貝,于是函數重定義的連接錯誤發生。但是老一些的C++實現對付這種情況的辦法是通過把一個un-inlined函數當作static來處理。因此每一份函數拷貝僅僅在自己的編譯單元中可見,這樣鏈接錯誤就解決了,但是在程序中卻會留下多份函數拷貝。在這種情況下,程序的性能不但沒有提升,反而增加了編譯和鏈接時間以及最終可執行體的大小。

但是幸運的是,新的C++標準中關于un-inlined函數的說法已經改變。一個符合標準C++實現應該只生成一份函數拷貝。然而,要想所有的編譯器都支持這一點可能還需要很長時間。

另外關于C++內聯函數還有兩個更令人頭疼的問題。***個問題是該如何進行維護。一個函數開始的時候可能以內聯的形式出現,但是隨著系統的擴展,函數體可能要求添加額外的功能,結果內聯函數就變得不太可能,因此需要把inline specifier去除以及把函數體放到一個單獨的源文件中。另一個問題是當內聯函數被應用在代碼庫的時候產生。當內聯函數改變的時候,用戶必須重新編譯他們的代碼以反映這種改變。然而對于一個非內聯函數,用戶僅僅需要重新鏈接就可以了。

這里想要說的是,內聯函數并不是一個增強性能的靈丹妙藥。只有當函數非常短小的時候它才能得到我們想要的效果,但是如果函數并不是很短而且在很多地方都被調用的話,那么將會使得可執行體的體積增大。最令人煩惱的還是當編譯器拒絕內聯的時候。在老的實現中,結果很不盡人意,雖然在新的實現中有很大的改善,但是仍然還是不那么完善的。一些編譯器能夠足夠的聰明來指出哪些函數可以內聯哪些不能,但是,大多數編譯器就不那么聰明了,因此這就需要我們的經驗來判斷。如果C++內聯函數不能增強行能,就避免使用它!

 

責任編輯:曹凱 來源: 博客園
相關推薦

2010-02-02 17:02:37

C++虛構函數

2013-02-01 15:59:41

社交媒體

2015-06-17 12:25:29

云計算

2021-11-19 23:15:38

大數據零售交通

2013-01-08 14:11:14

JavaJDK8lambda

2013-01-09 09:38:34

Java 8JDK8新版Java

2021-03-09 10:11:26

區塊鏈技術數據

2013-09-29 16:31:22

瀏覽器Chrome

2021-03-17 14:22:09

VRAR虛擬現實技術

2010-09-28 10:17:53

WiFi

2019-12-05 18:00:39

物聯網智能手表機器人

2014-08-28 10:06:57

SQL Server

2010-02-01 15:47:04

C++內聯函數

2023-11-20 09:57:03

內聯函數C++

2013-04-08 09:24:31

FacebookFacebook Ho

2018-10-27 14:49:25

2010-05-21 15:51:32

2022-06-05 15:02:57

邊緣計算云計算

2011-06-29 15:29:59

關鍵詞

2015-11-11 09:16:30

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 插插宗合网 | 成年人视频免费在线观看 | 久久99精品久久久久久秒播九色 | 国产免费看 | 欧美高清视频一区 | 一区二区不卡视频 | 男插女下体视频 | 免费福利视频一区二区三区 | 国产亚洲一区精品 | 久草新在线 | 久久综合一区 | 亚洲精品在线视频 | 九九99九九精彩46 | 午夜看电影在线观看 | 日韩免费毛片视频 | 男人的天堂久久 | 亚洲精品一区二区三区中文字幕 | 午夜视频在线观看视频 | 91视频中文| 户外露出一区二区三区 | 一级黄色片毛片 | 麻豆国产一区二区三区四区 | 国产在线观看一区二区三区 | 亚洲综合色网站 | 日韩精品一区在线 | 一区2区 | 日韩精品久久久久久 | 欧美成年黄网站色视频 | 国产精品欧美精品日韩精品 | 欧美激情 一区 | 小草久久久久久久久爱六 | 少妇一级淫片免费播放 | 91影库| 久久精品国产精品青草 | 在线视频 欧美日韩 | 一级做a爰片性色毛片视频停止 | 91视在线国内在线播放酒店 | 久久精品免费观看 | 欧美亚洲视频 | 中文字幕视频一区二区 | 久久精品99 |