當前位置:首頁 » 編程語言 » c語言有沒有引用
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言有沒有引用

發布時間: 2022-12-27 04:00:04

❶ 請問c語言中引用怎樣理解

1、引用的理解

引用是引入了對象的一個同義詞。定義引用的表示方法與定義指針相似,只是用&代替了*。

例如: Point pt1(10,10);

Point &pt2=pt1; 定義了pt2為pt1的引用。通過這樣的定義,pt1和pt2表示同一對象。

需要特別強調的是引用並不產生對象的副本,僅僅是對象的同義詞。因此,當下面的語句執行後:

pt1.offset(2,2);

pt1和pt2都具有(12,12)的值。

引用必須在定義時馬上被初始化,因為它必須是某個東西的同義詞。你不能先定義一個引用後才

初始化它。例如下面語句是非法的:

Point &pt3;

pt3=pt1;

2、引用的兩個主要用途

作為函數參數以及從函數中返回左值。

(1)引用參數

a、傳遞可變參數

傳統的c中,函數在調用時參數是通過值來傳遞的,這就是說函數的參數不具備返回值的能力。所以在傳統的c中,如果需要函數的參數具有返回值的能力,往往是通過指針來實現的。比如,實現兩整數變數值交換的c程序如下:

void swapint(int *a,int *b)

{

int temp;

temp=*a;

a=*b;

*b=temp;

}

使用引用機制後,以上程序的c++版本為:

void swapint(int &a,int &b)

{

int temp;

temp=a;

a=b;

b=temp;

}

調用該函數的c++方法為:swapint(x,y); c++自動把x,y的地址作為參數傳遞給swapint函數。

b、給函數傳遞大型對象

當大型對象被傳遞給函數時,使用引用參數可使參數傳遞效率得到提高,因為引用並不產生對象的副本,也就是參數傳遞時,對象無須復制。下面的例子定義了一個有限整數集合的類:

const maxCard=100;

Class Set

{

int elems[maxCard]; // 集和中的元素,maxCard 表示集合中元素個數的最大值。

int card; // 集合中元素的個數。

public:

Set () {card=0;} //構造函數

friend Set operator * (Set ,Set ) ; //重載運算符號*,用於計算集合的交集 用對象作為傳值參數

// friend Set operator * (Set & ,Set & ) 重載運算符號*,用於計算集合的交集 用對象的引用作為傳值參數

...

}

先考慮集合交集的實現

Set operator *( Set Set1,Set Set2)

{

Set res;

for(int i=0;i<Set1.card;++i)

for(int j=0;j>Set2.card;++j)

if(Set1.elems[i]==Set2.elems[j])

{

res.elems[res.card++]=Set1.elems[i];

break;

}

return res;

}

由於重載運算符不能對指針單獨操作,我們必須把運算數聲明為 Set 類型而不是 Set * 。每次使用*做交集運算時,整個集合都被復制,這樣效率很低。我們可以用引用來避免這種情況。

Set operator *( Set &Set1,Set &Set2)

{ Set res;

for(int i=0;i<Set1.card;++i)

for(int j=0;j>Set2.card;++j)

if(Set1.elems[i]==Set2.elems[j])

{

res.elems[res.card++]=Set1.elems[i];

break;

}

return res;

}

2、引用返回值

如果一個函數返回了引用,那麼該函數的調用也可以被賦值。這里有一函數,它擁有兩個引用參數並返回一個雙精度數的引用:

double &max(double &d1,double &d2)

{

return d1>d2?d1:d2;

}

由於max()函數返回一個對雙精度數的引用,那麼我們就可以用max() 來對其中較大的雙精度數加1:

max(x,y)+=1.0;

(1)c語言有沒有引用擴展閱讀

使用c語言中引用的原因

程序按功能劃分可分為數值運算、符號處理和I/O操作三類,符號處理程序占相當大的比例,符號處理程序無處不在,編譯器、瀏覽器、Office套件等程序的主要功能都是符號處理。

在程序中通過對函數的調用來執行函數體,其過程與其它語言的子程序調用相似。

C語言中,函數調用的一般形式為:

函數名(實際參數表)

對無參函數調用時則無實際參數表。實際參數表中的參數可以是常數、變數或其它構造類型數據及表達式。各實參之間用逗號分隔。字元函數引用即對引用有關庫函數或自定義函數函數。

❷ c語言中有沒有「引用」這個概念

其實c語言沒有引用,只是作為取地址;引用符「&」是c++語言中有

❸ C語言有引用傳遞嗎

c語言沒有引用傳遞,只有c++有,c語言中函數參數總是通過值傳遞,可以通過顯示傳遞指針值模擬引用傳遞,而直接用&的引用傳遞會報錯,你那程序把源文件改成cpp文件應該能用,至於嚴老師的只是偽代碼,提供一個程序運行結構而已,大體按照c語言編寫,有一部分是c++的東西

❹ 為什麼C語言中可以用引用 啊

c語言中沒有引用,如果在c語言中用了引用而編譯器沒報錯,唯一的可能是用的c++編譯器。

❺ c語言中什麼叫引用

引用(reference)是c++對c語言的重要擴充。引用引入了對象的一個同義詞。定義引用的表示方法與定義指針相似,只是用&代替了*,例如: Point pt1(10,10)。

Point &pt2=pt1;,定義了pt2為pt1的引用。通過這樣的定義,pt1和pt2表示同一對象。

需要特別強調的是引用並不產生對象的副本,僅僅是對象的同義詞,引用必須在定義時馬上被初始化,因為它必須是某個東西的同義詞。

循環結構:

循環結構可以減少源程序重復書寫的工作量,用來描述重復執行某段演算法的問題,這是程序設計中最能發揮計算機特長的程序結構,C語言中提供四種循環,即goto循環、while循環、do while循環和for循環。

四種循環可以用來處理同一問題,一般情況下它們可以互相代替換,但一般不提倡用goto循環,因為強制改變程序的順序經常會給程序的運行帶來不可預料的錯誤。

特別要注意在循環體內應包含趨於結束的語句(即循環變數值的改變),否則就可能成了一個死循環,這是初學者的一個常見錯誤。

❻ c語言中沒有引用,但是我看嚴蔚敏的書中怎麼用了引用

嚴格來講,C語言沒有引用只有指針,引用是C++中的東西。考試為了保險還是別用引用了

❼ c語言有引用嗎,c++才有,對嗎

1 引用類型是C++提供的,C語言之所以能夠使用是因為其使用的C++編譯器且源文件後綴是.cpp
2 分析
    cpp即C++(C Plus Plus),是C++程序的源文件。若是將源文件後綴改為.c,則引用類型是不可以使用的,如下圖,源文件為source.c

3 擴展
    由於C++對C幾乎完全兼容,所以大多數人們都選用C++編譯器來寫C程序

❽ C語言中引用指的是什麼,舉個例子

C語言裡面沒有引用的說法,只有C++裡面有。C++里引用就是給變數定義一個別名,操作這個別名就是操作原變數。

比如,我們定義一個引用:

inta=10;//定義一個普通變數
int&ref=a;//定義一個變數a的引用
ref=20;//這里對ref進行操作其實就是對a進行操作

變數主要是在參數傳遞的時候非常有用,當你的函數參數是一個值參數的時候,我們一般的做法是傳遞一個指針進去,這樣就導致我們在函數里操作的都是指針,這樣其實很不方便,如果使用引用的話就可以非常方便。

比如定義一個參數是引用的函數

voidfunc(int&b)
{
b++;
}
//調用
inta=100;
func(a);//調用的時候直接傳遞參數進去

上面的方式可以實現和指針一樣的效果,但是更加方便

❾ 請問c語言中引用怎樣理解

是引用類型嗎?C語言中沒有引用類型,引用類型是C++的,意思是為已有變數起一個別名。如int a,&b=a;,就定義了b是變數a的別名。通俗點說,可以理解為a、b是同一個變數的不同符號而已。

❿ c語言有沒有引用

c語言中並沒有引用!
引用是C++中的。
C++之父提議,少用指針,盡量使用引用。
因為,幾乎使用指針的地方都可以用引用替代,
使用引用是對目標變數的直接操作,而指針是
間接操作,不產生內存副本……等等好處