###実現したいこと
C言語によるプログラミングを行っていて、構造体の配列を初期化しようとしています。
###発生している問題・エラーメッセージ
初期化ならこうすればいけるんじゃないかと以下のコードを追加したところ、実行不可の状況に陥りました。
###該当のソースコード
C
1/* 細かい所は省略し、追加したコードだけを書いてます。 2 また、[std]は構造体(ポインタ)です。 */ 3int f, g; 4 5for(f = 0; f < 2; f++){ 6 for(g = 0; g < 4; g++){ 7 std->cards[f][g] = 0; 8 } 9}
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/10/22 14:56
回答2件
0
stdは構造体ポインタということで、malloc等で確保されたものであればcalloc等に置き換えることで対応が可能かと思いましたが、質問者さんの前回の質問を参照すると、stdの実定義は下記かと推測します。
c
1typedef struct status{ 2 int hp; 3 int cards[2][4]; 4 int have[5]; 5} Sta;
初期化処理として全ての値を0とする操作を行うとした場合、単純に下記としましたが、cardsの初期化処理は質問者さんの記述と同様です。
そのため、実行不可の状況
は該当の処理とは別の箇所によるものではないかと推測します。
c
1#include <stdio.h> 2 3typedef struct status{ 4 int hp; 5 int cards[2][4]; 6 int have[5]; 7} Sta; 8 9void init(Sta* std) 10{ 11 int i, j; 12 std->hp = 0; 13 for (i = 0; i < 2; i++) 14 { 15 for (j = 0; j < 4; j++) 16 { 17 std->cards[i][j] = 0; 18 } 19 } 20 for (i = 0; i < 5; i++) 21 { 22 std->have[i] = 0; 23 } 24} 25 26void print(Sta* std) 27{ 28 int i, j; 29 printf("hp: %d\n", std->hp); 30 for (i = 0; i < 2; i++) 31 { 32 for (j = 0; j < 4; j++) 33 { 34 printf("cards[%d][%d]: %d\n", i, j, std->cards[i][j]); 35 } 36 } 37 for (i = 0; i < 5; i++) 38 { 39 printf("have[%d]: %d\n", i, std->have[i]); 40 } 41} 42 43int main(void) 44{ 45 Sta std; 46 47 printf("-- 初期化前\n"); 48 print(&std); 49 50 init(&std); 51 52 printf("\n"); 53 printf("-- 初期化後\n"); 54 print(&std); 55 56 return 0; 57} 58 59/* 60実行結果: 61 62$ ./a.out 63-- 初期化前 64hp: 1 65cards[0][0]: 0 66cards[0][1]: 4196397 67cards[0][2]: 0 68cards[0][3]: 0 69cards[1][0]: 0 70cards[1][1]: 0 71cards[1][2]: 0 72cards[1][3]: 4196320 73have[0]: 0 74have[1]: 4195632 75have[2]: 0 76have[3]: -748586032 77have[4]: 32767 78 79-- 初期化後 80hp: 0 81cards[0][0]: 0 82cards[0][1]: 0 83cards[0][2]: 0 84cards[0][3]: 0 85cards[1][0]: 0 86cards[1][1]: 0 87cards[1][2]: 0 88cards[1][3]: 0 89have[0]: 0 90have[1]: 0 91have[2]: 0 92have[3]: 0 93have[4]: 0 94*/ 95
また、この構造体の構成であれば、Null0lluNさんのご回答にあるmemsetによる対応でも大きな問題はないものと考えます。
c
1#include <stdio.h> 2#include <string.h> 3 4typedef struct status{ 5 int hp; 6 int cards[2][4]; 7 int have[5]; 8} Sta; 9 10 11void print(Sta* std) 12{ 13 int i, j; 14 printf("hp: %d\n", std->hp); 15 for (i = 0; i < 2; i++) 16 { 17 for (j = 0; j < 4; j++) 18 { 19 printf("cards[%d][%d]: %d\n", i, j, std->cards[i][j]); 20 } 21 } 22 for (i = 0; i < 5; i++) 23 { 24 printf("have[%d]: %d\n", i, std->have[i]); 25 } 26 27} 28 29int main(void) 30{ 31 Sta std; 32 33 printf("-- 初期化前\n"); 34 print(&std); 35 36 memset(&std, 0, sizeof(Sta)); 37 38 printf("\n"); 39 printf("-- 初期化後\n"); 40 print(&std); 41 42 return 0; 43} 44 45/* 46実行結果: 47 48$ ./a.out 49-- 初期化前 50hp: 1 51cards[0][0]: 0 52cards[0][1]: 4196333 53cards[0][2]: 0 54cards[0][3]: 0 55cards[1][0]: 0 56cards[1][1]: 0 57cards[1][2]: 0 58cards[1][3]: 4196256 59have[0]: 0 60have[1]: 4195696 61have[2]: 0 62have[3]: 1855798112 63have[4]: 32767 64 65-- 初期化後 66hp: 0 67cards[0][0]: 0 68cards[0][1]: 0 69cards[0][2]: 0 70cards[0][3]: 0 71cards[1][0]: 0 72cards[1][1]: 0 73cards[1][2]: 0 74cards[1][3]: 0 75have[0]: 0 76have[1]: 0 77have[2]: 0 78have[3]: 0 79have[4]: 0 80*/
投稿2017/10/24 21:52
退会済みユーザー
総合スコア0
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
構造体の宣言部分や型等が書かれていないため、コードそのものの修正方法は提示できませんが、
c
1memset( std, 0, sizeof(std) );
としておけばどのような構造体であっても初期化できるかと思います。
投稿2017/10/24 09:19
総合スコア59
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/10/24 11:49
2017/10/24 12:35
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。