配列の作成方法
//创建一个数组-存放整型-10个
int arr[10] = { 1, 2, 3 };
このようにして、1次元配列を作成しました
が、配列を作成するには、定数を[]で指定する必要があり、変数は使用できないことに注意してください。
配列の初期化:配列の初期化とは、配列の作成中に配列の内容にいくつかの妥当な初期値(初期化)を与えることを指します。
例えば:
int arr1[10] = {1,2,3};//这样是不完全的初始化,剩下的元素默认初始化为0
配列の作成時に、特定のサイズの配列を指定したくない場合は、初期化する必要があります。配列内の要素の数は、初期化されたコンテンツに従って決定されます。ただし、次のコードを区別するために、メモリを割り当てる方法。
int main()
{
char arr4[] = "abcdef";
printf("%d\n", sizeof(arr4));
//sizeof 计算 arr4所占空间的大小
//7个元素-char 7*1 = 7
printf("%d\n", strlen(arr4));
//strlen 求字符串的长度 -'\0'之前的字符个数
//[abcdef\0]
//6
return 0;
}
ここで、strlenとsizeofの違いを知る必要があります。1。strlenとsizeof
は
2とは関係ありません。strlenは文字列の長さを見つけることです-文字列ライブラリ関数の長さのみ-参照ヘッダーファイル
3を使用します。 sizeof計算変数、配列とタイプのサイズ-単位はバイト演算子です
1次元配列は、
[]添え字参照演算子を使用します。これは、実際には配列アクセスの演算子です。
まとめ
1.配列には、0から始まる添え字を使用してアクセスします。
2.配列のサイズを計算できます。
1次元配列のメモリへの保存
int main()
{
int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
int sz = sizeof(arr) / sizeof(arr[0]);
int i = 0;
for (i = 0; i < sz; i++)
{
printf("&arr[%d] = %p\n",i, &arr[i]);
}
}
上記は出力結果です。arr[0]からarr [9]まで、配列インデックスが増加すると、要素のアドレスも定期的に増加することがわかります。アレイはメモリに継続的に格納されていると結論付けることができます。
次は2次元配列の作成です
int arr[3][4];
char arr[3][5];
float arr[2][4];
2次元配列の初期化
int arr[3][4] = {1,2,3,4};
int arr[3][4] = {{1,2},{3,4}};
int arr[][4] = {{1,2},{3,4}};
このとき、鋭い目の友人は、2次元配列では2次元配列の初期化行であるため、3番目の2次元配列の前の代表的な行の[]に番号がないことを見つけることができます。省略できますが、列は省略できません。(補足:int arr [3] [4]は、3行4列の作成を表します)
2次元配列の使用2次元配列の使用も下付き文字を使用します。
2次元配列のメモリへの保存
int main()
{
int arr[3][4];
int i = 0;
for (i = 0; i < 3; i++)
{
int j = 0;
for (j = 0; j < 4; j++)
{
printf("&arr[%d][%d] = %p\n", i, j, &arr[i][j]);
}
}
return 0;
}
結果の印刷:結果から、
1次元配列と同様に、2次元配列がメモリに連続的に格納されていることがわかります。
2021.1.26
常に愚かなコンピュータを信じる