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

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

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

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

Q&A

解決済

2回答

1035閲覧

エラーメッセージ「コアダンプ」の原因が分からない

tamajava

総合スコア3

C

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

0グッド

0クリップ

投稿2022/05/21 09:04

編集2022/05/21 11:08

前提

C言語でリストを用いてキューを実現するプログラムを作っています。
数回エンキューを行い、それ以上の回数のデキューを行ったところ、設定した「queue is empty」というエラーメッセージが表示されず、コアダンプが発生しました。

実現したいこと

  • キューに値が入っていないときにデキューを行った際に「queue is empty」と表示される

発生している問題・エラーメッセージ

$ ./a.exe enqueue: e, dequeue: d e Input key 1 enqueue: e, dequeue: d e Input key 2 enqueue: e, dequeue: d d key:1 enqueue: e, dequeue: d d key:2 enqueue: e, dequeue: d d Segmentation fault (コアダンプ)

該当のソースコード

C言語

1#include<stdio.h> 2#include<stdlib.h> 3 4typedef struct s_queue{ 5 int key; 6 struct s_queue *next; 7} QUEUE; 8 9QUEUE *queuetop, *queuerear; 10 11int main(void) 12{ 13 int n; 14 char s[2]; 15 queuetop = NULL; 16 queuerear = NULL; 17 18 printf("enqueue: e, dequeue: d\n"); 19 while(scanf("%1s", s) != EOF) { 20 switch (s[0]){ 21 case 'e': 22 case 'E': 23 printf("Input key\n"); 24 scanf("%d", &n); 25 enqueue(n); 26 break; 27 case 'd': 28 case 'D': 29 printf("key:%d\n", dequeue()); 30 break; 31 } 32 printf("enqueue: e, dequeue: d\n"); 33 } 34 return(0); 35} 36 37void enqueue(int k) 38{ 39 QUEUE *new; 40 QUEUE *newqueue(void); 41 42 new = newqueue(); 43 new->key = k; 44 if(queuerear == NULL){ 45 queuetop = new; 46 queuerear = new; 47 } 48 else { 49 queuerear->next = new; 50 queuerear = new; 51 } 52} 53 54int dequeue(void) 55{ 56 QUEUE *w; 57 int k; 58 59 if(queuetop == NULL){ 60 printf("queue is empty\n"); 61 exit(1); 62 } 63 else { 64 k = queuetop->key; 65 w = queuetop; 66 queuetop = w->next; 67 free(w); 68 } 69 return k; 70} 71 72QUEUE *newqueue(void) 73{ 74 QUEUE *p; 75 76 p = (QUEUE *)malloc(sizeof(QUEUE)); 77 if(p == NULL){ 78 fputs("malloc failed\n", stderr); 79 exit(1); 80 } 81 else { 82 return p; 83 } 84}

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

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

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

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

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

hoshi-takanori

2022/05/21 09:13

Objective-C のタグがついてますが、普通の C 言語の質問のようなので、タグを修正していただけると助かります。 https://teratail.com/tags/C
tamajava

2022/05/21 11:10

申し訳ありません、間違えて設定していたようです。 只今修正いたしました。
guest

回答2

0

bash

1$ gcc -std=gnu18 -fsanitize=address -Wall -Wextra -g queue.c -o queue 2$ ./queue 3 4 : 5 6key:2 7enqueue: e, dequeue: d 8d 9AddressSanitizer:DEADLYSIGNAL 10================================================================= 11==446020==ERROR: AddressSanitizer: SEGV on unknown address (pc 0x5565559856da bp 0x7ffe147ca390 sp 0x7ffe147ca380 T0) 12==446020==The signal is caused by a READ memory access. 13==446020==Hint: this fault was caused by a dereference of a high value address (see register values below). Dissassemble the provided pc to learn which register was used. 14 #0 0x5565559856da in dequeue queue.c:67 15 #1 0x556555985517 in main queue.c:32

※ キューに値が入っていないときには NULL になっているはずの queuetop の値が NULL ではなかったことが原因
queue.c

c

1int dequeue(void) 2{ 3 QUEUE *w; 4 int k; 5 6 if(queuetop == NULL){ 7 printf("queue is empty\n"); 8 exit(1); 9 } 10 else { 11 k = queuetop->key; ## <= 67行目 12 w = queuetop; 13 queuetop = w->next; 14 free(w); 15 } 16 return k; 17}

投稿2022/05/21 09:38

melian

総合スコア19805

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

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

0

ベストアンサー

newqueueのときに、キューのnextが初期化されてません
#NULL入れましょう

投稿2022/05/21 09:24

y_waiwai

総合スコア87774

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

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

tamajava

2022/05/21 11:27

キューはスタックと違いリストの末尾に値を追加していくので, 要素を追加するごとにnextの初期化が必要なんですね。すごく勉強になりました。 ご回答いただきありがとうございます。
y_waiwai

2022/05/21 11:29

いや、単にmallocで領域確保すると、そのナカミは不定だから、ということですね ゼロクリアされてません
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問