恩,有的編譯器初始化時候會產生這樣的參數
1. 幾種C++ 常見的參數種類
- int main(void);
- int main();
- int main(int argc, char **argv); //等價於int main(int argc, char *argv[]),是否等價呢?是不是前一個可以表示任意長度的任意個數組,后一個只是定長的任意個數的數組?見下面
- int main(int argc, char *argv[]);
- int main(int argc, char arg[][]);
- argc=3,表示除了程序名外還有2個參數。 argv[0]指向輸入的程序路徑及名稱。 argv[1]指向參數para_1字符串。 argv[2]指向參數para_2字符串。
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]=12546
第二個參數存在argv[2]中,以此類推。
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]是取第一個參數的字符數組的首地址。
指針數組和數組指針問題
這兩個名字不同當然所代表的意思也就不同。我剛開始看到這就嚇到了,主要是中文太博大精深了,整這樣的簡稱太專業了,把人都繞暈了。從英文解釋或中文全稱看就比較容易理解。
指針數組:array of pointers,即用於存儲指針的數組,也就是數組元素都是指針
數組指針: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]的首地址。 ..
然后我們看驗證結果: