scanf和printf函數是系統定義的函數,函數的首部和函數體在定義的時候有。我們用的時候一直看到的是已經定義好了的,系統默認有效的。
成都創新互聯專注于網站建設|成都網站維護公司|優化|托管以及網絡推廣,積累了大量的網站設計與制作經驗,為許多企業提供了網站定制設計服務,案例作品覆蓋成都水電改造等行業。能根據企業所處的行業與銷售的產品,結合品牌形象的塑造,量身策劃品質網站。
所以不需要在程序開頭重新寫出來函數頭部分。
擴展資料:
scanf()是C語言中的一個輸入函數。與printf函數一樣,都被聲明在頭文件stdio.h里,因此在使用scanf函數時要加上#include stdio.h。(在有一些實現中,printf函數與scanf函數在使用時可以不使用預編譯命令#include stdio.h。)它是格式輸入函數,即按用戶指定的格式從鍵盤上把數據輸入到指定的變量之中。
printf:
格式輸出,它是c語言中產生格式化輸出的函數(在 stdio.h 中定義)。用于向終端(顯示器、控制臺等)輸出字符。格式控制由要輸出的文字和數據格式說明組成。
函數action1被定義了2次。
將
void action1(int x,int y)
{
printf("x*y=%d\n",x*y);
}
改為
void action2(int x,int y)
{
printf("x*y=%d\n",x*y);
}
編譯器錯誤 C2001 錯誤消息
常數中有換行符
字符串常數不能繼續到第二行,除非進行下列操作:
?用反斜杠結束第一行。
?用一個雙引號結束第一行上的字符串,并在下一行用另一個雙引號開始該字符串。
用 \n 結束第一行是不夠的。
編譯器錯誤 C2002 錯誤消息
無效的寬字符常數
多字節字符常數是非法的。
通過檢查下面的可能原因進行修復
1.寬字符常數包含的字節比需要的多。
2.未包括標準頭文件 STDDEF.h。
3.寬字符不能與一般字符串連接。
4.寬字符常數之前必須是字符“L”:
編譯器錯誤 C2003 錯誤消息
應輸入“defined id”
標識符必須跟在預處理器關鍵字之后。
編譯器錯誤 C2004 錯誤消息
應為“defined(id)”
標識符必須出現在預處理器關鍵字之后的括號中。
也可能由于為 Visual Studio .NET 2003 進行的編譯器一致性工作生成此錯誤:在預處理器指
令中缺少括號。
如果預處理器指令缺少右括號,則編譯器將生成一個錯誤。
編譯器錯誤 C2005 錯誤消息
#line 應跟一個行號,卻找到“token”
#line 指令后面必須跟行號。
編譯器錯誤 C2006 錯誤消息
“directive”應輸入文件名,卻找到“token”
諸如 #include 或 #import 等指令需要文件名。若要解決該錯誤,請確保 token 是一個有效
文件名。并且將該文件名放在雙引號或尖括號中。
編譯器錯誤 C2007 錯誤消息
#define 語法
#define 后未出現標識符。若要解決該錯誤,請使用標識符。
編譯器錯誤 C2008 錯誤消息
“character”: 宏定義中的意外
該字符緊跟在宏名之后。若要解決該錯誤,宏名之后必須有一個空格。
編譯器錯誤 C2009 錯誤消息
宏形式“identifier”重復使用
宏定義的形參表多次使用該標識符。宏的參數列表中的標識符必須是唯一的。
編譯器錯誤 C2010 錯誤消息
“character”: 宏形參表中的意外
該字符在宏定義的形參表中使用不正確。移除該字符以解決該錯誤。
編譯器錯誤 C2011 錯誤消息
“identifier”:“type”類型重定義
該標識符已定義為 type 類型。如果多次將某個類型庫導入同一個文件,也可能生成 C2011
。
編譯器錯誤 C2012 錯誤消息
在“”之后缺少名稱
#include 指令缺少所需的文件名。
編譯器錯誤 C2013 錯誤消息
缺少“”
#include 指令缺少右尖括號。添加右尖括號以解決該錯誤。
編譯器錯誤 C2014 錯誤消息
預處理器命令必須作為第一個非空白空間啟動
預處理器指令的 # 符號必須是非空白行上的第一個字符。
編譯器錯誤 C2015 錯誤消息
常數中的字符太多
一個字符常數包含的字符多于兩個。標準字符常數只能包含一個字符,長字符常數只能包含兩
個字符。
轉義序列(如 \t)將被轉換為單個字符。
當使用 Microsoft 擴展將字符常數轉換為整數時,也可能發生 C2015。
編譯器錯誤 C2017 錯誤消息
非法的轉義序列
轉義序列(如 \t)出現在字符或字符串常數之外。
當 stringize 運算符與包括轉義序列的字符串一起使用時會發生 C2017。
編譯器錯誤 C2018 錯誤消息
未知字符“hexnumber”
源文件包含一個意外的 ASCII 字符,該字符由其十六進制數標識。若要解決該錯誤,請移除
該字符。
編譯器錯誤 C2019 錯誤消息
應找到預處理器指令,卻找到“character”
該字符跟在 # 符號的后面,但它不是預處理器指令的第一個字母。
編譯器錯誤 C2020 錯誤消息
“member”:“class”成員重定義
從基類或結構繼承的成員被重定義。不能重定義繼承成員,除非它在基類中被聲明為 virtual
。
編譯器錯誤 C2021 錯誤消息
應輸入指數值,而非“character”
用作浮點常數的指數的字符是一個無效數字。確保使用的指數在范圍之內。
編譯器錯誤 C2022 錯誤消息
“number”: 對字符來說太大
字符或字符串常數中跟在反斜杠 (\) 后面的八進制數字太大,不能表示字符。
編譯器錯誤 C2026 錯誤消息
字符串太大,已截斷尾部字符
該字符串的長度超過了 16380 個單字節字符的**。
連接相鄰字符串之前,字符串的長度不能超過 16380 個單字節字符。
大約為此長度的一半的 Unicode 字符串也會生成此錯誤。
編譯器錯誤 C2027 錯誤消息
使用了未定義類型“type”
類型只有經過定義才能使用。若要解決該錯誤,請確保在引用類型前已對其進行了完全定義。
有可能聲明一個指向已聲明但未定義的類型的指針。但是 Visual C++ 不允許引用未定義的類
型。
編譯器錯誤 C2028 錯誤消息
結構/聯合成員必須在結構/聯合中
結構或聯合成員必須在結構或聯合內部聲明。
編譯器錯誤 C2030 錯誤消息
“identifier”: 結構/聯合成員重定義
結構或聯合將同一標識符用于多個成員。
編譯器錯誤 C2032 錯誤消息
“identifier”: 函數不能是結構/聯合“structorunion”的成員
該結構或聯合中的一個成員函數在 C++ 中允許使用而在 C 中卻不允許。若要解決該錯誤,請
編譯為 C++ 程序或移除該成員函數。
編譯器錯誤 C2033 錯誤消息
“identifier”: 位域不能有間接尋址
該位域被聲明為指針,這是不允許的。
編譯器錯誤 C2034 錯誤消息
“identifier”: 位域類型對于位數太小
該位域聲明中位的數目超過了基類型的大小。
編譯器錯誤 C2036 錯誤消息
“identifier”: 未知的大小
對 identifier 的操作需要數據對象的大小,而該大小無法確定。
編譯器錯誤 C2039 錯誤消息
“identifier1”: 不是“identifier2”的成員
該代碼錯誤調用或引用了結構、類或聯合的成員。
編譯器錯誤 C2040 錯誤消息
“operator”:“identifier1”與“identifier2”的間接尋址級別不同
涉及該運算符的表達式具有不一致的間接尋址級別。
如果兩個操作數都是算術的或都是非算術的(如數組或指針),則不用更改就可使用它們。如
果一個操作數是算術的,而另一個不是,則算術運算符將轉換為非算術類型。
編譯器錯誤 C2041 錯誤消息
非法的數字“character”(用于基“number”)
指定的字符不是基(如八進制或十六進制)的有效數字。
編譯器錯誤 C2042 錯誤消息
signed/unsigned 關鍵字互相排斥
在單個聲明中使用關鍵字 signed 和 unsigned。
編譯器錯誤 C2043 錯誤消息
非法 break
break 僅在 do、for、while 或 switch 語句中合法。
編譯器錯誤 C2044 錯誤消息
非法 continue
continue 僅在 do、for 或 while 語句中合法。
編譯器錯誤 C2045 錯誤消息
“identifier”: 標簽重定義
該標簽出現在同一函數中的多條語句之前。
編譯器錯誤 C2046 錯誤消息
非法的 case
關鍵字 case 只能出現在 switch 語句中。
編譯器錯誤 C2047 錯誤消息
非法的 default
關鍵字 default 僅能出現在 switch 語句中。
編譯器錯誤 C2048 錯誤消息
默認值多于一個
switch 語句包含多個 default 標簽。刪除其中一個 default 標簽可解決該錯誤。
編譯器錯誤 C2050 錯誤消息
switch 表達式不是整型
switch 表達式計算結果為一個非整數值。若要解決該錯誤,請在 switch 語句中只使用整數
值。
編譯器錯誤 C2051 錯誤消息
case 表達式不是常數
Case 表達式必須是整數常數。
編譯器錯誤 C2052 錯誤消息
“type”: 非法的 case 表達式類型
Case 表達式必須是整數常數。
編譯器錯誤 C2053 錯誤消息
“identifier”: 寬字符串不匹配
寬字符串被分配給了一個不兼容的類型。
編譯器錯誤 C2054 錯誤消息
在“identifier”之后應輸入“(”
該函數標識符用在需要尾部括號的上下文中。
導致該錯誤的可能原因是省略了復雜初始化上的等號 (=)。
編譯器錯誤 C2055 錯誤消息
應輸入形參表,而不是類型表
函數定義包含參數類型列表而不包含形參表。ANSI C 需要命名的形參,除非它們是 void 或
是省略號 (...)。
編譯器錯誤 C2056 錯誤消息
非法表達式
表達式因前一個錯誤而無效。
編譯器錯誤 C2057 錯誤消息
應輸入常數表達式
上下文要求常數表達式,即其值在編譯時已知的表達式。
編譯器錯誤 C2058 錯誤消息
常數表達式不是整型
該上下文需要整數常數表達式。
編譯器錯誤 C2059 錯誤消息
語法錯誤 :“token”
該標記導致語法錯誤。
若要確定原因,則不僅要檢查在錯誤信息中列出的行,還要檢查該行上面的行。下面的示例對
聲明 j 的行生成了錯誤信息,而該錯誤的真正源卻出現在其上面的行中。
如果對行的檢查沒有獲得有關可能出現的問題的任何線索,則嘗試注釋掉在錯誤信息中列出的
行以及可能出現在該行上面的若干行。
如果該錯誤信息在緊跟 typedef 變量的符號上出現,則檢查該變量是否已在源代碼中定義。
如果符號沒有計算出任何結果(在使用 /Dsymbol= 編譯時可能發生),可能會導致 C2059。
可能收到 C2059 的另一個特定原因是編譯在函數的默認參數中指定了結構的應用程序。參數的
默認值必須是一個表達式。初始值設定項列表(如用于初始化結構的初始值設定項列表)不是表達式。其解決方法是定義一
個執行所需初始化的構造函數。
編譯器錯誤 C2060 錯誤消息
語法錯誤 : 遇到文件結束
至少還需要一個標記。
編譯器錯誤 C2061 錯誤消息
語法錯誤: 標識符“identifier”
編譯器發現了不應在此出現的標識符。請確保在使用 identifier 之前對其進行聲明。
初始值設定項可能括在了括號中。為避免該問題,請將聲明符括在括號中或使其成為 typedef
。
在編譯器將表達式作為類模板參數檢測時也可能導致此錯誤;使用 typename 告訴編譯器它是
一個類型。
編譯器錯誤 C2062 錯誤消息
意外的類型“type”
編譯器不需要類型名稱。
編譯器處理構造函數的參數列表中未定義類型的方式也可能導致 C2062。如果編譯器遇到未定
義的(拼錯了嗎?)類型,則它假定構造函數是一個表達式,并發出 C2062。若要解決此錯誤,請只使用構造函數參數列表
中的定義類型。
編譯器錯誤 C2063 錯誤消息
“identifier”: 不是函數
該標識符用作函數,但未聲明為函數。
編譯器錯誤 C2064 錯誤消息
項不會計算為接受“number”個參數的函數
通過表達式調用了函數。該表達式未計算為函數指針。
編譯器錯誤 C2065 錯誤消息
“identifier”: 未聲明的標識符
在可使用變量的類型前必須在聲明中指定它。在可以使用函數前必須在聲明或原型中指定該函
數使用的參數。
可能的原因:
1.您正在用 C 運行庫的調試版本進行編譯,在 for 循環中聲明標準 C++ 庫迭代器變量,然后
嘗試在 for 循環范圍外使用該迭代器變量。 用 C 運行庫的調試版本編譯標準 C++ 庫代碼暗指使用 /Zc:forScope。有關更
多信息,請參見調試迭代器支持。
2.可能正在調用當前不受生成環境支持的 SDK 頭文件中的函數。
3.省略必要的包含文件,尤其是在定義 VC_EXTRALEAN、WIN32_LEAN_AND_MEAN 或
WIN32_EXTRA_LEAN 時。這些符號從 windows.h 和 afxv_w32.h 中排除了一些頭文件以加快編譯。(在 windows.h 和
afxv_w32.h 中查找排除的頭文件的最新說明。)
4.標識符名拼寫錯誤。
5.標識符使用了錯誤的大小寫字母。
6.字符串常數的后面缺少右引號。
7.命名空間范圍不正確。例如,若要解析 ANSI C++ 標準庫函數和運算符,則必須用 using 指
令指定 std 命名空間。下面的示例未能編譯,因為 using 指令被注釋掉,并且在 std 命名空間中定義了 cout:
編譯器錯誤 C2066 錯誤消息
轉換到函數類型是非法的
在 ANSI C 中,函數指針和數據指針間的轉換是非法的。
編譯器錯誤 C2067 錯誤消息
轉換到數組類型是非法的
對象被轉換成了數組類型。
編譯器錯誤 C2069 錯誤消息
“void”項到非“void”項的強制轉換
類型 void 不能轉換成任何其他類型。
編譯器錯誤 C2070 錯誤消息
“type”: 非法的 sizeof 操作數
sizeof 運算符需要一個表達式或類型名稱。
編譯器錯誤 C2071 錯誤消息
“identifier”: 非法的存儲類
聲明 identifier 所用的存儲類無效。
編譯器錯誤 C2072 錯誤消息
“identifier”: 函數的初始化
錯誤指定了函數初始值設定項。
編譯器錯誤 C2073 錯誤消息
“identifier”: 部分初始化數組的元素必須有默認構造函數
為用戶定義的類型或常數的數組指定的初始值設定項太少。如果沒有為數組成員指定明確的初
始值設定項及其對應的構造函數,則必須提供默認的構造函數。
編譯器錯誤 C2074 錯誤消息
“identifier”:“class-key”初始化需要大括號
在指定的類、結構或聯合初始值設定項兩邊沒有大括號。
編譯器錯誤 C2075 錯誤消息
“identifier”: 數組初始化需要大括號
在指定的數組初始值設定項兩邊沒有大括號。
編譯器錯誤 C2077 錯誤消息
非標量字段初始值設定項“identifier”
試圖用非標量(結構、聯合、數組或類)初始化位域。使用整數值或浮點值。
編譯器錯誤 C2078 錯誤消息
初始值設定項太多
初始值設定項的數目超過了要初始化的對象數。
編譯器錯誤 C2079 錯誤消息
“identifier”使用未定義的類/結構/聯合“name”
指定的標識符是一個未定義的類、結構或聯合。
初始化匿名聯合時,可能會導致此錯誤。
編譯器錯誤 C2081 錯誤消息
“identifier”: 形參表中的名稱非法
標識符導致語法錯誤。
此錯誤可能是由使用形參表的舊形式導致的。必須在形參表中指定形參的類型。
編譯器錯誤 C2082 錯誤消息
形參“identifier”的重定義
在函數體中重新聲明了函數的形參。若要解決該錯誤,請移除該重定義。
編譯器錯誤 C2083 錯誤消息
結構/聯合比較非法
結構或聯合直接與另一個用戶定義的類型進行比較。這是不允許的,除非已經定義了比較運算
符或者存在到標量類型的轉換。
編譯器錯誤 C2084 錯誤消息
函數“function”已有主體
函數已經定義。
在以前的 Visual C++ 版本中,
?編譯器將接受解析為同一實際類型的多個模板的專用化,盡管附加的定義將永遠不可用?,F
在編譯器將檢測這些多重定義。
?__int32 和 int 已被視為單獨的類型。編譯器現在將 __int32 作為 int 的同義詞處理。這
意味著,如果函數同時在 __int32 和 int 上重載,編譯器將檢測多個定義,并提供一個錯誤。
編譯器錯誤 C2085 錯誤消息
“identifier”: 不在形參表中
該標識符在函數定義中聲明而未在形參表中聲明。(僅用于 ANSI C)
編譯器錯誤 C2086 錯誤消息
“identifier”: 重定義
多次定義了該標識符,或者后面的聲明與前一個不同。
C2086 也可能是增量編譯引用的 C# 程序集的結果。重新生成該 C# 程序集以解決此錯誤。
編譯器錯誤 C2087 錯誤消息
“identifier”: 缺少下標
具有多個下標的數組的定義缺少大于 1 的維度的下標值。
編譯器錯誤 C2088 錯誤消息
“operator”: 對于“class-key”非法
沒有為結構或聯合定義該運算符。該錯誤只對 C 代碼有效。
編譯器錯誤 C2089 錯誤消息
“identifier”:“class-key”太大
指定的結構或聯合超過 4GB 的**。
編譯器錯誤 C2090 錯誤消息
函數返回數組
函數不能返回數組。請返回指向數組的指針。
編譯器錯誤 C2091 錯誤消息
函數返回函數
函數不能返回函數。請返回指向函數的指針。
編譯器錯誤 C2092 錯誤消息
“array name”數組元素類型不能是函數
不允許使用函數數組。請使用指向函數的指針的數組。
編譯器錯誤 C2093 錯誤消息
“variable1”: 無法使用自動變量“variable2”的地址初始化
在用 /Za 編譯時,程序試圖將自動變量的地址用作初始值設定項。
編譯器錯誤 C2094 錯誤消息
標簽“identifier”未定義
goto 語句使用的標簽在函數中不存在。
編譯器錯誤 C2095 錯誤消息
“function”: 實參具有類型“void”:“number”參數
傳遞給函數的參數為 void 類型,這是不允許的。請改為使用指向 void 的指針 (void *)。
number 指示哪一個參數為 void。
編譯器錯誤 C2097 錯誤消息
非法的初始化
通過檢查下面的可能原因進行修復
1.使用非常數值初始化變量。
2.用長地址初始化短地址。
3.在用 /Za 編譯時,用非常數表達式初始化局部結構、聯合或數組。
4.用包含逗號運算符的表達式初始化。
5.用既非常數又非符號的表達式初始化。
編譯器錯誤 C2099 錯誤消息
初始值設定項不是常數
此錯誤只由 C 編譯器發出,而且只對非自動變量發生。編譯器在程序的開頭對非自動變量進
行初始化,并且用于對這些變量進行初始化的值必須是常數。
由于編譯時與運行時的浮點精度環境設置(有關更多信息,請參見 _controlfp_s)可能不同
,因此,編譯器無法在 /fp:strict 下對表達式執行常數合并。在這種情況下,也可能發生 C2099。
當常數合并失敗時,編譯器調用動態初始化,這在 C 中是不允許的。
要解決此錯誤,請將模塊編譯為 .cpp 文件或對表達式進行簡化。
int main()
{
int fun()
{
int a;
cina;
return a;
}
fun();
}
這叫在主函數定義函數,是不允許的
首先不要忘了,要用getch()必須引入頭文件conio.h,以前學c語言的時候,我們總喜歡用在程序的末尾加上它,利用它來實現程序運行完了暫停不退出的效果。如果不加這句話,在tc2.0的環境中我們用ctrl+f9編譯并運行后,程序一運行完了就退回到tc環境中,我們根本來不及看到結果,這時要看結果,我們就要按alt+f5回到dos環境中去看結果,這很麻煩。而如果在程序的結尾加上一行getch();語句,我們就可以省掉會dos看結果這個步驟,因為程序運行完了并不退出,而是在程序最后把屏幕停住了,按任意鍵才退回到tc環境中去。那我們來看看getch()到底起的什么作用,getch()實際是一個輸入命令,就像我們用cin的時候程序會停下來等你輸入,和cin不同的是,getch()的作用是從鍵盤接收一個字符,而且并不把這個字符顯示出來,就是說,你按了一個鍵后它并不在屏幕上顯示你按的什么,而繼續運行后面的代碼,所以我們在c++中可以用它來實現“按任意鍵繼續”的效果,即程序中遇到getch();這行語句,它就會把程序暫停下來,等你按任意鍵,它接收了這個字符鍵后再繼續執行后面的代碼。 你也許會問,為什么我們在c++中就沒有在程序的末尾加上getch(),解釋是,軟件總是不斷更新的,不好的地方當然要進行改正,getch()加在程序末尾,它又不賦值給任何變量,所以它在這個地方完全是垃圾代碼,與程序無關。c++中考慮到這一點,于是在每次程序運行完了并不退出,而是自動把屏幕停下來,并顯示“press any key...”叫你按任意鍵退出,這就好比c++在它的環境中運行程序,在程序的末尾自動加上了一行getch();語句,并且在這行語句前還添加了一行輸出語句cout"press any key...";來提示你程序結束了,按任意鍵繼續。實際上我們編譯好的程序在程序結束了本身是不會停下來的,我們可以在編譯產生的debug目錄中找到這個編譯好的應用程序(擴展名exe),在文件夾中雙擊運行它,你會發現屏幕閃了一下ms-dos窗口就關閉了,因為程序運行完就自動退出了,回到了windows環境,當然,如果我們在dos環境中運行這個程序,我們就可以直接在看到dos屏幕上看到程序運行結果,因為程序運行完后并不清屏。 還有一個語句,和getch()很相似,getche(),它也需要引入頭文件conio.h,那它們之間的區別又在哪里呢?不同之處就在于getch()無返回顯示,getche()有返回顯示。怎么說呢?我舉個例子你就明白了。 詳細請參考 a href="" target="_blank";/a
本文題目:c語言中函數已有主體,C語言只有一個主函數嗎
文章起源:http://www.hntjjpw.com/article30/hdhgso.html
成都網站建設公司_創新互聯,為您提供面包屑導航、靜態網站、小程序開發、微信公眾號、手機網站建設、建站公司
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯