最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(wǎng) 會員登陸 & 注冊

經(jīng)驗(yàn)分享:C語言初學(xué)者常見的 22 個(gè)錯(cuò)誤!建議收藏起來

2022-10-30 16:06 作者:C語言編程__Plus  | 我要投稿



一.語言使用錯(cuò)誤

在打代碼的過程中,經(jīng)常需要在中文與英文中進(jìn)行轉(zhuǎn)換,因此常出現(xiàn)一些符號一不小心就用錯(cuò),用成中文。例如:“;”中文中的分號占用了兩個(gè)字節(jié),而英文中“;”分號只占用一個(gè)字節(jié)。編譯器只能識別英文。因此會報(bào)錯(cuò)。在報(bào)錯(cuò)后檢查這些字符時(shí)最需要眼力和時(shí)間的。因此打代碼是需注意。

二.忘打分號

分號是C語言是語句的標(biāo)志,在C中無分號不成語句,無語句不能識別。

在編譯中如果沒有分號,編譯器就會將,b=2合到上一個(gè)語句a=1中,進(jìn)而出現(xiàn)語法錯(cuò)誤。


三.多打分號

復(fù)合語句中,花括號后不應(yīng)再加分號,雖然不會有什么影響,但是多此一舉,毫無意義。


另外,if(a == 0)后不應(yīng)加分號,if(a ==0)后加分號就會是語句提前結(jié)束,而使用if的目的就是為了控制其后的語句,加了分號之后。程序?qū)⒂肋h(yuǎn)執(zhí)行i++,不論a是否等于0.


for()后不應(yīng)加分號。


本意是輸入4個(gè)數(shù),每輸入一個(gè)數(shù)后再將它輸出。由于for()后多加了個(gè)分號,導(dǎo)致循環(huán)變成空語句,此時(shí)就變成只能輸入一個(gè)數(shù)并輸出了。

四.變量命名的錯(cuò)誤

C語言規(guī)定,標(biāo)示符由字母,數(shù)字和下劃線“_"組成,它的第一個(gè)字母必須是字母或下劃線。

在C語言中變量的命名不允許出現(xiàn)的情況有以下三種:1.以數(shù)字開頭進(jìn)行開頭;2.不能包含運(yùn)算符;3.不能與系統(tǒng)保留字(即關(guān)鍵字重名)。一旦出現(xiàn)這三種情況之一,編譯器就會報(bào)錯(cuò)。如下圖所示:


這里附上C語言中的關(guān)鍵字,即用作專用的定義符,也稱為保留字。


作為C語言的初學(xué)者,變量的命名往往是簡單單調(diào)的。而程序員大佬往往用具有特定意義的英文單詞進(jìn)行命名,并形成了一套自己的命名法則:業(yè)界目前共有四種命名法則;駝峰命名法,匈牙利命名法,帕斯卡命名法和下劃線命名法。其中前三種是比較流行的命名法。1.駝峰命名法是將每個(gè)單詞(邏輯斷點(diǎn))用大寫字母區(qū)分開。2.匈牙利命名法通過在變量名前面加上小寫字母的符號標(biāo)識作為前綴,標(biāo)識出變量的作用域,類型等。3.帕斯卡命名法。與駝峰命名法類似,只不過將開頭首字母換成了大寫字母。4.下劃線命名法是將每個(gè)單詞(邏輯斷點(diǎn))用下劃線隔開。


五.忽略大小寫字母的區(qū)別


出現(xiàn)這種情況編譯器會將a和A認(rèn)為是兩個(gè)不同的變量,因而報(bào)錯(cuò)。因此在定義變量和輸出變量的同時(shí)要注意大小寫字母的一致性。因?yàn)镃會將大寫字母和小寫字母看成是不同的字符。

六.數(shù)據(jù)類型的使用錯(cuò)誤

例如:我們要輸出一個(gè)a = 3.1415的情形。如果數(shù)據(jù)類型使用錯(cuò)誤,將得不到我們想要的結(jié)果。使用整型,將只輸出3。必須使用浮點(diǎn)型float,double,long double。


七.“/”運(yùn)算時(shí),和“%”時(shí)計(jì)算結(jié)果的錯(cuò)誤

“/”運(yùn)算時(shí),參與運(yùn)算的兩個(gè)數(shù)均為整型時(shí),結(jié)果為舍去小數(shù)的整型數(shù),例如;


盡管定義了浮點(diǎn)型但是結(jié)果卻是1.0,而不是我們想要的1.5。為得到1.5的結(jié)果,我們必須將3/2改成3.0/2,或者是3/2.0.才能輸出1.5的結(jié)果。


如果除數(shù)和被除數(shù)中有一個(gè)為負(fù)值,其結(jié)果與具體實(shí)現(xiàn)有關(guān)。例如:“-9/7”在有的系統(tǒng)中計(jì)算結(jié)果為-2,有的系統(tǒng)計(jì)算結(jié)果為-1,這是對小數(shù)部分的舍入處理不同造成的?!?”要求參與的運(yùn)算操作數(shù)均為整型,計(jì)算結(jié)果的符號與“%”左側(cè)運(yùn)算對象的符號相同,如“-9/4"的結(jié)果為-1。一旦非整型,編譯器將報(bào)錯(cuò)。


也就是說整型變量a和b可以進(jìn)行求余運(yùn)算,而實(shí)型變量則不允許進(jìn)行“求余”運(yùn)算。

八.字符常量和字符串常量的表示錯(cuò)誤

字符變量是用類型符char定義字符變量,字符常量是由一對單引號扣起來的單個(gè)字符;字符串常量是用雙引號括起來的字符序列,在C中通常以“/”作為結(jié)束標(biāo)志。像下面的字符串"a",實(shí)際上包含兩個(gè)字符'a'和'',這把它們賦給一個(gè)變量是不行的。


九.“=”與“==”的混淆

在C語言中“=”是賦值運(yùn)算符,而“==”則是關(guān)系運(yùn)算符。命名的不同者也就意味著作用不同和優(yōu)先級的不同。關(guān)系運(yùn)算符的的優(yōu)先級高于賦值運(yùn)算符。


if()括號中的語句是進(jìn)行判斷的內(nèi)容,判斷a是否等于4,所以說里面的符號應(yīng)該用關(guān)系運(yùn)算符“==”而不是賦值運(yùn)算符“=”。正確的表示如下:


十.scanf()括號中忘記加地址運(yùn)算符“&”


這樣的書寫時(shí)不合法的。scanf函數(shù)是格式輸入函數(shù),它從標(biāo)準(zhǔn)輸入設(shè)備(鍵盤)讀取輸入信息。也就是按照啊a,b在內(nèi)存的地址將a,b的值存進(jìn)去,“&a”就是指a在內(nèi)存中的地址。

十一.間隔符的不注意

scanf()函數(shù)一般以空格鍵,Tab鍵或Enter鍵作為分隔符,當(dāng)格式中字符傳中存在非格式字符時(shí),輸入時(shí)也需要一并輸入。例如:


應(yīng)當(dāng)輸入:


十二.輸入數(shù)據(jù)時(shí)結(jié)束情況的不熟悉

C語言中,輸入數(shù)據(jù)時(shí),遇到以下3種情況則認(rèn)為該數(shù)據(jù)結(jié)束:

1.遇空格鍵,Tab鍵,或Enter鍵;

2.有指定數(shù)據(jù)長度時(shí),系統(tǒng)自動按長度截??;

3.遇非法輸入。

十三.輸入字符的格式與要求不一致

在C中,在用“%c”輸入時(shí),空格和轉(zhuǎn)義字符均作為有效字符。


字符“a”賦給c1,字符“ ”賦給c2,字符“b”送給c3,因?yàn)?c只要求讀入一個(gè)字符,后面不需要用空格作為兩個(gè)字符的間隔。

十四.輸入數(shù)據(jù)時(shí)規(guī)定精度


輸入數(shù)據(jù)時(shí)企圖規(guī)定精度,這樣做在C中是不合法的。

十五.使用switch語句中漏寫break語句

例如:打印學(xué)生成績


如果漏寫break語句,case只起標(biāo)號作用,而不起判斷作用。也就是假如輸入A,就會直接執(zhí)行到最后一個(gè)printf語句,而不會在第一個(gè)printf語句執(zhí)行后截止。因此必須在每個(gè)printf語句后加上break.例如:


十六.數(shù)組的部分錯(cuò)誤

1.數(shù)組后面的元素個(gè)數(shù)應(yīng)與聲明的一致。如果與聲明不一致,超出聲明后面的數(shù)字默認(rèn)為0。


2.必須聲明元素個(gè)數(shù)。


十七.忽略了while和do-while語句在細(xì)節(jié)上的區(qū)別

如圖所示,當(dāng)輸入i大于10時(shí)二者的結(jié)果就不同了。這是因?yàn)閣hile循環(huán)是先判斷后執(zhí)行,而do-while循環(huán)是先執(zhí)行后判斷。對于大于10的數(shù),while語句中編譯器不循環(huán)循環(huán)體,而do-while語句編譯器則要執(zhí)行一次循環(huán)體。

十八.定義數(shù)組時(shí)誤用變量

數(shù)組后面用方括號括起來的是常量表達(dá)式,可以包含常量和符號常量。即C不允許對數(shù)組的大小作動態(tài)定義。

十九.多加了地址運(yùn)算符“&”

C語言中,scanf函數(shù)中的輸入是字符數(shù)組名時(shí),就不必在加地址符&。需改為:


二十.同時(shí)定義了形參和函數(shù)中的局部變量

形參應(yīng)該在函數(shù)體外定義,而局部變量應(yīng)該在函數(shù)體內(nèi)定義。應(yīng)改為:


二十一.在定義數(shù)組時(shí)將定義的“元素個(gè)數(shù)”誤以為是可使的最大下標(biāo)值

C語言規(guī)定:定義時(shí)用a[10],表示數(shù)組有10個(gè)元素。其下標(biāo)值由0開始,所以數(shù)組元素a[10]是不存在的。

二十二.二維數(shù)組的定義

1.C語言中,不能使用一次方括號來表示二維數(shù)組的元素,表示非法的例子如下:

2.另外,由于系統(tǒng)不會檢查二維數(shù)組元素的下標(biāo)是否越界,以此需要編程人員注意限制下標(biāo)不要越界。例如:

希望對于初學(xué)者的你有幫助!

另外的話為了幫助大家,輕松,高效學(xué)習(xí)C語言/C++,我給大家分享我收集的資源,從最零基礎(chǔ)開始的教程到C語言項(xiàng)目案例,幫助大家在學(xué)習(xí)C語言的道路上披荊斬棘!

微信公眾號:C語言編程學(xué)習(xí)基地

整理分享(多年學(xué)習(xí)的源碼、項(xiàng)目實(shí)戰(zhàn)視頻、項(xiàng)目筆記,基礎(chǔ)入門教程)最重要的是你可以在群里面交流提問編程問題哦!



經(jīng)驗(yàn)分享:C語言初學(xué)者常見的 22 個(gè)錯(cuò)誤!建議收藏起來的評論 (共 條)

分享到微博請遵守國家法律
南涧| 静乐县| 涞源县| 南安市| 白山市| 司法| 台北市| 棋牌| 满城县| 五家渠市| 喀什市| 台中县| 类乌齐县| 武威市| 梁平县| 邓州市| 舟山市| 贵溪市| 巴林右旗| 龙胜| 石屏县| 明溪县| 永济市| 铜川市| 樟树市| 文化| 仪陇县| 湖口县| 论坛| 石楼县| 洪雅县| 普兰店市| 西乡县| 桓台县| 宽城| 太湖县| 若尔盖县| 苏尼特右旗| 兴义市| 饶阳县| 八宿县|