質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

2回答

12685閲覧

構造体の中にある配列の初期化の方法が分からず…

Cat_N_Memory

総合スコア11

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2017/10/22 06:57

編集2017/10/22 06:58

###実現したいこと
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ページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

maisumakun

2017/10/22 08:23

stdの型と、宣言部分についても追記していただけましたら幸いです。
yumetodo

2017/10/22 14:56

加えて実行不可の状況の詳細も追記してください
guest

回答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

Null0lluN

総合スコア59

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Null0lluN

2017/10/24 12:35

初期化というのは確かに語弊がありましたね。ゼロクリアというべきでした。 回答のトップに書いてある通り、構造体の宣言部分や型等が書かれていないため、コードそのものの修正方法は提示できないのですが、以下の理由から今回の回答をいたしました。 リンク先にもある通り、確かに「構成する全ビットが 0 になったとしても、オブジェクトの値が 0 になるかどうかは分からない」ですが、(特に構造体を動的配列にする場合)コンパイラによっては構造体が初期化されていないと警告を吐く場合がありますので初期化しているっぽくしてあげるのに使えるのではないかと。どうせ、あとから構造体の値をどんどん代入していくわけですし。 あとは、「おまじない」的な意味もなくはないです。一文だけでコードの見た目はきれいですので。 ちなみに、リンク先にあった「ゼロクリアしたい理由は、多くの場合、memcmp を使って一致判定を行いたいことが理由でしょう。」とありましたが、それは考慮していませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問