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

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

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

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

Q&A

解決済

2回答

404閲覧

ポインタのswap処理の添削をお願いしたいです

pikahyogo

総合スコア3

C

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

0グッド

0クリップ

投稿2021/07/31 16:27

質問内容

動的メモリ確保解放の練習として以下のコードを書きました。確保したメモリを自分で全て解放したい場合、freeの仕方は合っているでしょうか?他にも間違った点があったら指摘お願いします。

該当のソースコード

c

1#include <stdio.h> 2#include <stdlib.h> 3#include <string.h> 4int main() 5{ 6 char *x, *y, *tmp; 7 char a[100] = "hello"; 8 char b[100] = "abc"; 9 x = (char *)malloc(strlen(a) + 1); 10 strcpy(x, a); 11 y = (char *)malloc(strlen(b) + 1); 12 strcpy(y, b); 13 tmp = x; 14 x = y; 15 y = tmp; 16 free(x); 17 free(y); 18}

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

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

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

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

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

guest

回答2

0

ベストアンサー

printf("%p", ポインタ) で任意のポインタ値を出力できます。
mallocの直後/freeの直前にポインタ値を出力し、それぞれがひとつずつ現れていればOK.

投稿2021/07/31 21:32

episteme

総合スコア16612

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

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

pikahyogo

2021/08/01 00:49

なるほど。では、合ってそうですね。ありがとうございました。
guest

0

malloc/freeについては既に良回答があるのでそちらにおまかせするとして。

他にも間違った点があったら

とのことなので、重箱の隅をつつきます。

  • C++ではなくC言語であれば

int main()
int main(void)のほうがよい気がします。
C言語では引数リストが空なのはvoidと等価ではありません。そしてCの規格ではプログラムの開始点の標準的なものとして決められているものの一つがint main(void)であってint main()ではないのです。
一方、プログラムの開始点の規格には「処理系が認めるもの」というのもあるので、コンパイラが文句をいわないなら「間違ってはいない」ということにもなるのですが。

  • mallocでメモリ取得操作をしたら、結果としてちゃんと取得できたかどうか(NULLが返ってきていないか)チェックするのがお作法でしょう。

  • char a[] = "hello";ではなくchar a[100] = "hello";にした意図があるはずです。その意図に対してmalloc(100)ではなくmalloc(strlen(a) + 1);という記述をしたことは整合するでしょうか?

投稿2021/07/31 23:00

thkana

総合スコア7703

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

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

pikahyogo

2021/08/01 00:48

回答ありがとうございます。今度からvoid使いますね。 char = a[100]にした理由は、いつもループで違う大きさの文字列を格納するという処理を書いていたのでその名残で書いていました。確かにこのプログラムだとa[]でいいですね。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問