C語(yǔ)言詳細(xì)分析講解關(guān)鍵字goto與void的作用
一、關(guān)于goto
- 高手潛規(guī)則:禁用 goto
- 項(xiàng)目經(jīng)驗(yàn):程序質(zhì)量與 goto 的出現(xiàn)次數(shù)成反比
- 最后的判決:將 goto 打入冷宮
下面看一段 goto 副作用分析的代碼:
#include <stdio.h>
#include <malloc.h>
void func(int n)
{
int* p = NULL;
if( n < 0 )
{
goto STATUS;
}
p = (int*)malloc(sizeof(int) * n);
STATUS:
p[0] = n;
free(p);
}
int main()
{
printf("begin...\n");
printf("func(1)\n");
func(1);
printf("func(-1)\n");
func(-1);
printf("end...\n");
return 0;
}下面為輸出結(jié)果:

這段代碼中當(dāng) func 的入口參數(shù) n 的值小于 0 時(shí),就會(huì) goto 到STATUS 那里去執(zhí)行代碼,但是由于跳過(guò)了分配內(nèi)存環(huán)節(jié),就不能把 n 的值賦給 p[0],強(qiáng)行賦值就會(huì)發(fā)成段錯(cuò)誤。
二、void 的意義
void 修飾函數(shù)返回值和參數(shù)
- 如果函數(shù)沒(méi)有返回值,那么應(yīng)該將其聲明為 void
- 如果函數(shù)沒(méi)有參數(shù),應(yīng)該聲明其參數(shù)為 void
void 修飾函數(shù)返回值和參數(shù)是為了表示“無(wú)”
下面這段代碼就表示 f 函數(shù)的輸入?yún)?shù)沒(méi)有限制。

不存在 void 變量
- C語(yǔ)言沒(méi)有定義 void 究竟是多大內(nèi)存的別名
- 沒(méi)有 void 的標(biāo)尺
- 無(wú)法在內(nèi)存中裁剪出 void 對(duì)應(yīng)的變量
在下面的代碼中,只有 void* 那條語(yǔ)句可以編譯通過(guò),因?yàn)?void* 指針是合法的。

小貼士
- ANSI C:標(biāo)準(zhǔn) C 語(yǔ)言的規(guī)范
- 擴(kuò)展C:在 ANSI C 的基礎(chǔ)上進(jìn)行了擴(kuò)充

上面的代碼在 ASNI C編譯器中無(wú)法通過(guò)編譯,但是對(duì)于支持 GNU 標(biāo)準(zhǔn)的 gcc 編譯器而言是合法的。
void 指針的意義
- C 語(yǔ)言規(guī)定只有相同類型的指針才可以相互賦值
- void* 指針作為左值用于“接收”任意類型的指針
- void* 指針作為右值使用時(shí)需要進(jìn)行強(qiáng)制類型轉(zhuǎn)換

下面看一段通過(guò) void* 實(shí)現(xiàn) MemSet 函數(shù)的代碼:
#include <stdio.h>
void MemSet(void* src, int length, unsigned char n)
{
unsigned char* p = (unsigned char*)src;
int i = 0;
for(i=0; i<length; i++)
{
p[i] = n;
}
}
int main()
{
int a[5];
int i = 0;
MemSet(a, sizeof(a), 0);
for(i=0; i<5; i++)
{
printf("%d\n", a[i]);
}
return 0;
}下面為輸出結(jié)果:

void* 定義的 src 表示可以接收任意類型的指針,所以數(shù)組 a 可以是任意類型。
三、小結(jié)
- 現(xiàn)代軟件工程中禁用 goto 語(yǔ)句
- void 是一種抽象的數(shù)據(jù)類型
- void 類型不能用于定義變量
- void 類型用于聲明函數(shù)無(wú)參數(shù)
- void 類型用于聲明函數(shù)無(wú)返回值
- 可以定義 void* 類型的指針
- void* 類型的指針可以接受任意類型的指針值
到此這篇關(guān)于C語(yǔ)言詳細(xì)分析講解關(guān)鍵字goto與void的作用的文章就介紹到這了,更多相關(guān)C語(yǔ)言goto與void內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ LeeCode題目:比特位計(jì)數(shù)和買賣股票的最佳時(shí)機(jī)
這篇文章主要介紹了基于C語(yǔ)言計(jì)算比特位計(jì)數(shù)和買賣股票的最佳時(shí)機(jī),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-07-07
C++實(shí)現(xiàn)LeetCode(120.三角形)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(120.三角形),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++生成隨機(jī)浮點(diǎn)數(shù)的示例代碼
在C++11之前,我們通常采用rand函數(shù)來(lái)生成隨機(jī)數(shù),但rand函數(shù)對(duì)一些情況顯得難以處理。本文將介紹如何利用C++生成隨機(jī)浮點(diǎn)數(shù),需要的可以參考一下2022-04-04
C++使用new和delete進(jìn)行動(dòng)態(tài)內(nèi)存分配與數(shù)組封裝
這篇文章主要介紹了C++使用new和delete進(jìn)行動(dòng)態(tài)內(nèi)存分配與數(shù)組封裝,運(yùn)行期間才能確定所需內(nèi)存大小,此時(shí)應(yīng)該使用new申請(qǐng)內(nèi)存,下面我們就進(jìn)入文章學(xué)習(xí)具體的操作方法,需要的小伙伴可以參考一下2022-03-03
c++ 求數(shù)組最大最小值函數(shù)的實(shí)現(xiàn)
這篇文章主要介紹了c++ 求數(shù)組最大最小值函數(shù)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07

