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

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

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

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Q&A

解決済

2回答

1378閲覧

自動変数と静的変数の違い

kelt22

総合スコア46

C

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

0グッド

0クリップ

投稿2020/05/28 06:15

質問

下記のプログラムで静的変数である、main関数内のlistを自動変数として宣言すると最初のscanf文を読み込む前に実行中断してしまいます。自分ではこのプログラムだとlistが自動変数でも静的変数でも結果変わらないと思っていたのですが、なぜ実行中断してしまうのか解説していただけると有り難いです。

該当のソースコード

c

1#include <stdio.h> 2#include <string.h> 3#include <ctype.h> 4#include <stdlib.h> 5 6typedef struct List{ 7 int size; 8 int *number[1024]; 9}List; 10 11void initList(List *List){ 12 int i; 13 List->size=0; 14 for(i=0;i<1024;i++){ 15 List->number[i]=NULL; 16 } 17} 18 19void Listadd(List *List,int x){ 20 if(List->number[List->size/1024]==NULL){ 21 List->number[List->size/1024]=malloc(sizeof(int)*1024); 22 } 23 List->number[List->size/1024][List->size%1024]=x; 24 List->size++; 25} 26 27void ListPrint(List *List){ 28 int i; 29 for(i=0;i<List->size;i++){ 30 printf("%d ",List->number[i/1024][i%1024]); 31 } 32 printf("\n"); 33} 34 35void ListDelete(List *List){ 36 int i; 37 List->size=0; 38 for(i=0;i<1024;i++){ 39 free(List->number[i]); 40 List->number[i]=NULL; 41 } 42} 43 44 45int main(void){ 46 static List list[1024]; 47 int n,q,t,a,x; 48 int i; 49 scanf("%d%d",&n,&q); 50 for(i=0;i<n;i++){ 51 initList(&list[i]); 52 } 53 while(q--){ 54 scanf("%d%d",&a,&t); 55 if(a==0){ 56 scanf("%d",&x); 57 Listadd(&list[t],x); 58 }else if(a==1){ 59 ListPrint(&list[t]); 60 }else if(a==2){ 61 ListDelete(&list[t]); 62 } 63 } 64 return 0; 65}

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

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

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

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

guest

回答2

0

kazuma-sさんが仰るようにスタック・オーバフローが発生したのでしょうね。
自動変数はスタック領域に確保されるので、大きなサイズの変数宣言には向きません。

投稿2020/05/28 06:53

DreamTheater

総合スコア1095

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

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

0

ベストアンサー

Linux を使っていませんか?

コマンドラインで ulimit -a を実行してみてください。
スタックサイズの制限が 8Mバイトのはずです。

ポインタのサイズが 8バイトなら、sizeof(List) は 8Kバイトで
それを 1024個確保すると、8Mバイトを使い切ってしまいます。

投稿2020/05/28 06:30

kazuma-s

総合スコア8224

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

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

kelt22

2020/05/29 02:31

コマンドプロンプトを使っていますが、配列の要素数を1024から100に変更すると自動変数でもうまく実行できたのでスタック・オーバフローが起こっていたと思います。解説ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問