RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

C++中的const和引用的討論

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2020-12-24 15:35 ? 次閱讀

今天給大家分享一下這段時間學習c++的總結(jié)學習:c++里面的const關(guān)鍵字和引用。

一、const關(guān)鍵字的總結(jié)

1、const什么時候為只讀變量,什么時候又是常量呢?

(1)const常量的判別規(guī)則:

只用字面量初始化的const常量才會進入符號表

使用其它變量初始化的const常量仍然是只讀變量

被volatile修飾的const常量不會進入符號表

在編譯期間不能直接確定初始值的const標識符,都被作為只讀變量處理

(2)const引用的類型與初始化變量的類型

相同:初始化變量成為只讀變量

不同:生成一個新的只讀變量

代碼版本一:

#include <stdio.h>
int main()

const int x = 1;//直接得到值,進入符號表,但是還是會為 x 分配空間,只不過這個空間 x 沒有用而已
const int& rx = x;//rx代表只讀變量,這個變量是編譯器為x分配而沒有使用的空間;引用代表變量的別名,而變量代表一段內(nèi)存空間的別名,所以引用代表一段內(nèi)存空間的別名
int& nrx = const_cast<int&>(rx); //消除 rx只讀屬性,和rx 代表的內(nèi)存空間相同,同時c++里面的幾種類型轉(zhuǎn)換要掌握
nrx=5;
printf("x = %d",x);
printf("rx = %d",rx);
printf("nrx = %d",nrx);
printf("&x = %p",&x);
printf("&rx = %p",&rx);
printf("&nrx = %p",&nrx);

return 0;

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# ./a.out
x = 1
rx = 5
nrx = 5
&x = 0x7ffcc5fa8abc
&rx = 0x7ffcc5fa8abc
&nrx = 0x7ffcc5fa8abc

代碼版本二:

#include <stdio.h>
int main()

volatile const int y = 2;// 只讀變量,不會進入符號表
int *p = const_cast<int*>(&y);//y被 const修飾,取到的地址也有 const 屬性,這里將地址只讀屬性去掉
*p = 8;
printf("y = %d",y);
printf("p = %p",p);
return 0;

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# ./a.out
y = 8
p = 0x7ffd78559684

代碼版本三:

#include <stdio.h>
int main()

volatile const int y = 2;
int *p = const_cast<int*>(&y);
*p = 8;
printf("y = %d",y);
printf("p = %p",p);
const int z = y ;//只讀變量
p = const_cast<int*>(&z);
*p= 9;
printf("z = %d",z);
printf("p = %p",p);
return 0;

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# ./a.out
y = 8
p = 0x7ffc5d651250
z = 9
p = 0x7ffc5d651254

代碼版本四:

#include <stdio.h>
int main()

char c = 'c';
char& rc = c;
const int& trc = c; // char 類型默認轉(zhuǎn)換為 int;const 引用初始化類型不同,將得到新的只讀變量,所以改變 rc 和 trc 沒有絲毫關(guān)系,從我們的輸出結(jié)果可以看出來
rc = 'a';
printf("c = %c",c);
printf("rc = %c",rc);
printf("trc = %c",trc);
return 0;

結(jié)果輸出:

root@txp-virtual-machine:/home/txp# ./a.out
c = a
rc = a
trc = c

二、引用的總結(jié):

1、引用與指針有什么關(guān)系,以及如何理解"引用的本質(zhì)就是指針常量"?

(1)指針是一個常量:

值為一個內(nèi)存地址,不需要初始化,可以保存不同的地址

通過指針可以訪問對應內(nèi)存地址中的值

指針可以被const修飾成為常量或者只讀變量

(2)引用只是一個變量的新名字:

對引用的操作(賦值、取地址等)都會傳遞到代表的變量上

const引用使其代表的變量具有只讀屬性

引用必須在定義時初始化,之后無法代表其它變量

(3)從使用c++語言的角度來看:

引用與指針沒有任何的關(guān)系

引用是變量的新名字,操作引用就是操作對應的變量

(4)從c++編譯器的角度來看:

為了支持新概念"引用"必須要一個有效的解決方案

在編譯器內(nèi)部,使用指針常量來實現(xiàn)"引用"

因此"引用"在定義時必須初始化

(5)在工程項目開發(fā)中:

當進行c++編程時,直接站在使用的角度來看待引用,與指針毫無關(guān)系,引用就是變量的別名

當對C++代碼進行調(diào)試分析時,一些特殊情況,可以考慮站在C++編譯器的角度來看待引用

代碼實踐:

版本一:

#include <stdio.h>
int a = 2;
struct SV{
int& x;
int& y;
int& z;
};
int main()

int b =4;
int* pc = new int(3) ;
SV sv = {a,b,*pc};
printf("&sv.x = %p",&sv.x);
printf("&sv.y = %p",&sv.y);
printf("&sv.z = %p",&sv.z);
delete pc;
return 0;

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# ./a.out
&sv.x = 0x601050
&sv.y = 0x7ffee11ba794
&sv.z = 0x1cfd010

版本二:

#include <stdio.h>
int a = 2;
struct SV{
int& x;
int& y;
int& z;
};
int main()

int b =4;
int* pc = new int(3) ;
SV sv = {a,b,*pc};
int& array[] = {a,b,*pc};//數(shù)組中的每個元素是引用就不可以;error: declaration of ‘a(chǎn)rray’ as array of references;C++ 天生要支持 C 語言,C 語言中數(shù)組中的每個元素在內(nèi)存中是順序存放的,地址是遞增的,所以在 C++ 中也要兼容這個特性,而在 C++ 中唯有引用數(shù)組破快了這個特性,所以說 C++ 中不支持引用數(shù)組;&array[1] - &array[0] ?。?Expected ==> 4
printf("&sv.x = %p",&sv.x);
printf("&sv.y = %p",&sv.y);
printf("&sv.z = %p",&sv.z);
delete pc;
return 0;

輸出結(jié)果:

root@txp-virtual-machine:/home/txp# g++ test.cpp
test.cpp: In function ‘int main()’:
test.cpp:16:14: error: declaration of ‘a(chǎn)rray’ as array of references
int& array[] = {a,b,*pc};

三、總結(jié):

指針是一個變量

引用是一個變量的新名字

const引用能夠生成新的只讀變量

在編譯器內(nèi)部使用指針常量實現(xiàn)"引用"

編譯時不能直接確定初始值的const標識符都是只讀變量

好了,今天的分享就到這里,如果文章中有錯誤或者不理解的地方,可以交流互動,一起進步。我是txp,下期見!

審核編輯:符乾江
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 可編程邏輯
    +關(guān)注

    關(guān)注

    7

    文章

    515

    瀏覽量

    44083
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2108

    瀏覽量

    73618
  • CONST
    +關(guān)注

    關(guān)注

    0

    文章

    44

    瀏覽量

    8159
收藏 人收藏

    評論

    相關(guān)推薦

    C語言和C++結(jié)構(gòu)體的區(qū)別

    同樣是結(jié)構(gòu)體,看看在C語言和C++中有什么區(qū)別?
    的頭像 發(fā)表于 10-30 15:11 ?198次閱讀

    C7000優(yōu)化C/C++編譯器

    電子發(fā)燒友網(wǎng)站提供《C7000優(yōu)化C/C++編譯器.pdf》資料免費下載
    發(fā)表于 10-30 09:45 ?0次下載
    <b class='flag-5'>C</b>7000優(yōu)化<b class='flag-5'>C</b>/<b class='flag-5'>C++</b>編譯器

    使用OpenVINO GenAI API在C++構(gòu)建AI應用程序

    許多桌面應用程序是使用 C++ 開發(fā)的,而將生成式AI(GenAI)功能集成到這些應用程序可能會很具有挑戰(zhàn)性,尤其是因為使用像 Hugging Face 這樣的 Python 庫的復雜性。C++
    的頭像 發(fā)表于 10-12 09:36 ?366次閱讀
    使用OpenVINO GenAI API在<b class='flag-5'>C++</b><b class='flag-5'>中</b>構(gòu)建AI應用程序

    ostream在c++的用法

    ostream 是 C++ 標準庫中一個非常重要的類,它位于 頭文件(實際上,更常見的是通過包含 頭文件來間接包含 ,因為 包含了 和 )。 ostream 類及其派生類(如 std::cout
    的頭像 發(fā)表于 09-20 15:11 ?660次閱讀

    ModusToolbox 3.2在c代碼包含c++代碼的正確步驟是什么?

    使用 ModusToolbox 3.2 我有一個用純 C 語言編寫的 XMC4700 項目。 我正在嘗試添加一些 C++ 函數(shù),并將其合并到我的原始代碼。 我可以構(gòu)建獨立的 .cpp/.hpp
    發(fā)表于 07-23 08:21

    C++語言基礎(chǔ)知識

    電子發(fā)燒友網(wǎng)站提供《C++語言基礎(chǔ)知識.pdf》資料免費下載
    發(fā)表于 07-19 10:58 ?7次下載

    C++實現(xiàn)類似instanceof的方法

    函數(shù),可實際上C++沒有。但是別著急,其實C++中有兩種簡單的方法可以實現(xiàn)類似Java的instanceof的功能。 在 C++
    的頭像 發(fā)表于 07-18 10:16 ?573次閱讀
    <b class='flag-5'>C++</b><b class='flag-5'>中</b>實現(xiàn)類似instanceof的方法

    要用指針怎么引用,一般在file2.c引用file1.c的字符串數(shù)組是怎么操作的?

    (RTC_SET,sizeof(RTC_SET));編譯通不過;問題出在sizeof(RTC_SET), 討論:要用指針怎么引用,一般在file2.c
    發(fā)表于 05-09 08:05

    C/C++兩種宏實現(xiàn)方式

    #ifndef的方式受C/C++語言標準支持。它不僅可以保證同一個文件不會被包含多次,也能保證內(nèi)容完全相同的兩個文件(或者代碼片段)不會被不小心同時包含。
    的頭像 發(fā)表于 04-19 11:50 ?605次閱讀

    鴻蒙OS開發(fā)實例:【Native C++

    使用DevEco Studio創(chuàng)建一個Native C++應用。應用采用Native C++模板,實現(xiàn)使用NAPI調(diào)用C標準庫的功能。使用C標準庫hypot接口計算兩個給定數(shù)平方和的平
    的頭像 發(fā)表于 04-14 11:43 ?2591次閱讀
    鴻蒙OS開發(fā)實例:【Native <b class='flag-5'>C++</b>】

    使用 MISRA C++:2023? 避免基于范圍的 for 循環(huán)中的錯誤

    在前兩篇博客,我們?向您介紹了新的 MISRA C++ 標準?和?C++ 的歷史?。在這篇博客,我們將仔細研究以 C++
    的頭像 發(fā)表于 03-28 13:53 ?783次閱讀
    使用 MISRA <b class='flag-5'>C++</b>:2023? 避免基于范圍的 for 循環(huán)中的錯誤

    c語言,c++,java,python區(qū)別

    C語言、C++、Java和Python是四種常見的編程語言,各有優(yōu)點和特點。 C語言: C語言是一種面向過程的編程語言。它具有底層的特性,能夠?qū)τ嬎銠C硬件進行直接操作。
    的頭像 發(fā)表于 02-05 14:11 ?2360次閱讀

    vb語言和c++語言的區(qū)別

    VB語言和C++語言是兩種不同的編程語言,雖然它們都屬于高級編程語言,但在設計和用途上有很多區(qū)別。下面將詳細比較VB語言和C++語言的區(qū)別。 設計目標: VB語言(Visual Basic)是由
    的頭像 發(fā)表于 02-01 10:20 ?2257次閱讀

    C++在Linux內(nèi)核開發(fā)從爭議到成熟

    Linux 內(nèi)核郵件列表中一篇已有六年歷史的老帖近日再次引發(fā)激烈討論 —— 主題是建議將 Linux 內(nèi)核的開發(fā)語言從 C 轉(zhuǎn)換為更現(xiàn)代的 C++。
    的頭像 發(fā)表于 01-31 14:11 ?623次閱讀
    <b class='flag-5'>C++</b>在Linux內(nèi)核開發(fā)<b class='flag-5'>中</b>從爭議到成熟

    C++簡史:C++是如何開始的

    的 MISRA C++:2023 博客系列的第二部分。 在這篇博客,我們將深入探討 C++ 的歷史、編程語言多年來的發(fā)展歷程以及它的下一步發(fā)展方向。
    的頭像 發(fā)表于 01-11 09:00 ?581次閱讀
    <b class='flag-5'>C++</b>簡史:<b class='flag-5'>C++</b>是如何開始的
    RM新时代网站-首页