恩,有的編譯器初始化時候會產生這樣的參數ios
1. 幾種C++ 常見的參數種類數組
2. 參數的說明: int argc 表示main函數的參數個數,main函數至少有一個參數,即第一個參數爲該main函數所在程序名:即argv[0]的值, argc>=1函數
char ** argv 表示main函數所在的程序在運行時輸入的參數表,用,或者空格分隔:第一個參數存在 argv[1]中 每一個第二維數組單元存一位數,例如 biji 12546 即argv[1][0] = 1, argv[1][2]=2, argv[1][3]=5, argv[1][4]=5, argv[1][6]=6, 而argv[1]=12546post
第二個參數存在argv[2]中,以此類推。spa
3. 對於argv存入的其實是 字符數組, 若是要吧輸入的整數字符串轉換成整形數,能夠調用stl函數 atoi(&argv[1][0]) //注意,不能寫&argv[1] 編譯會報類型不匹配的錯誤 error: cannot convert `char**' to `const char*' for argument `1' to `int atoi(const char*)'命令行
&argv[1][0]是取第一個參數的字符數組的首地址。指針
指針數組和數組指針問題調試
這兩個名字不一樣固然所表明的意思也就不一樣。我剛開始看到這就嚇到了,主要是中文太博大精深了,整這樣的簡稱太專業了,把人都繞暈了。從英文解釋或中文全稱看就比較容易理解。code
指針數組:array of pointers,即用於存儲指針的數組,也就是數組元素都是指針blog
數組指針:a pointer to an array,即指向數組的指針
還要注意的是他們用法的區別,下面舉例說明。
int* a[4] 指針數組
表示:數組a中的元素都爲int型指針 (假如沒有*,那麼就是數組a中全爲int 類型的數據)
元素表示:*a[i] *(a[i])是同樣的,由於[]優先級高於*
int (*a)[4] 數組指針
表示:指向數組a的指針 (假如是int (*a),那麼就是指向整型a的指針)
元素表示:(*a)[i]
注意:在實際應用中,對於指針數組,咱們常常這樣使用:
typedef
int
* pInt;
pInt a[4];
這跟上面指針數組定義所表達的意思是同樣的,只不過採起了類型變換。
代碼演示以下:
#include <iostream>
using
namespace
std;
int
main()
{
int
c[4]={1,2,3,4};
int
*a[4];
//指針數組
int
(*b)[4];
//數組指針
b=&c;
//將數組c中元素賦給數組a
for
(
int
i=0;i<4;i++)
{
a[i]=&c[i];
}
//輸出看下結果
cout<<*a[1]<<endl;
//輸出2就對
cout<<(*b)[2]<<endl;
//輸出3就對
return
0;
}
注意:定義了數組指針,該指針指向這個數組的首地址,必須給指針指定一個地址,容易犯的錯得就是,不給b地址,直接用(*b)[i]=c[i]給數組b中元素賦值,這時數組指針不知道指向哪裏,調試時可能沒錯,但運行時確定出現問題,使用指針時要注意這個問題。但爲何a就不用給他地址呢,a的元素是指針,實際上for循環內已經給數組a中元素指定地址了。但若在for循環內寫*a[i]=c[i],這一樣會出問題。總之一句話,定義了指針必定要知道指針指向哪裏,否則要悲劇。
相似的還有指針函數和函數指針,遇到了再說吧。
思考:
有人這樣回覆的:
提醒樓主一點,雖然 c和&c的值是同樣的,但&c表示的是整個數組的首地址,c表示c[0]的首地址。 ..
而後咱們看驗證結果: