![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
2つの文字列を入力して別の文字列にコピーするプログラムをつくっているのですが、どこが間違っているのでしょうか?教えていただけませんか?
/*文字列連結*/
void *my_stract(char*, char*, char*);
void main(void)
{
char bun1[100],bun2[100],bun3[200];
printf("文字列1を入力してください\n"); gets(bun1);
printf("文字列2を入力してください\n"); gets(bun2);
my_stract(bun1,bun2,bun3);
puts(bun3);
}
char *my_stract(char *str3, char *str2, char *str1)
{
char *p1, *p2, *p3;
p1=str1;
p2=str2;
p3=str3;
while(*p1)
{
*p3=*p1;
p1++;
p3++;
}
while(*p2)
{
*p3=*p2;
p2++;
p3++;
}
*p3='\0';
return str3;
}
A 回答 (6件)
- 最新から表示
- 回答順に表示
No.6
- 回答日時:
「いくらなんでもそれはないだろ」的に巨大な間違いがあるなら, 突っ込んでいいと思いますけどね>#5.
とよそ向けに書いておくけど, 今までの回答で言われたことを理解できてる?
No.5
- 回答日時:
#1, #2 でもう説明してありますけど
>2つの文字列を入力して別の文字列にコピーするプログラムをつくっているのですが、どこが間違っているのでしょうか?教えていただけませんか?
>char *my_stract(char *str3, char *str2, char *str1)
この関数の説明を書いてみてください。
>my_stract(bun1,bun2,bun3);
その書いた説明の使い方に合っていますか。
#3のコードにも突っ込み入れたい・・・
No.4
- 回答日時:
あえて突っ込ませてもらいます>#3.
i < MAX_SRC という比較が全く意味不明. あと, 他の関数にあわせて dst を第1引数においた方がいいとか, src は const 付けてあげた方が親切だろうとか, いくつかありますけどね.
No.3
- 回答日時:
どこから突っ込めばいいやら…
bun1, bun2, bun3はbuf1, buf2, buf3のスペルミスでは…
my_stractもmy_strcatのスペルミスでは…
それはいいとして…
my_stractの一行目から、
char *p1, *p2, *p3;
p1=str1;
p2=str2;
p3=str3;
は要りません
while(*p1)は、p1がNULL終端してるのかも調べないで回しているので確認する必要があります。while(*p2)も同様
さらに、*p3は100しか容量がないのにただ*p1と*p2をくっつけたら容量をオーバーします。
また、これは定石なのですが、出力が文字列の場合は、戻り値ではなく引数で返るようにするべきです。
ですから、これらを実現するためには、
int my_strcat( char src1[], size_t lenSrc1, char stc2[], size_t lenSrc2, char[] dst, sizeof maxDst );
という形の関数とし、1つ目の文字列、その長さ、2つ目の文字列、その長さ、出力先、その最大長 を渡して、
戻り値には正常終了(例えば0)、出力先の長さが足りなかった(例えば1)、などとするべきです。
(標準のstrcatではこの安全機構がないのでミスを生みやすいです)
参考に、私が書いたソースを載せておきます。
(突貫工事なのでアホなことしてるかもしれません。 丸写しはやめてください。)
http://ideone.com/lXoPII
No.2
- 回答日時:
>char bun1[100],bun2[100],bun3[200];
>my_stract(bun1,bun2,bun3);
で、
>char *my_stract(char *str3, char *str2, char *str1)
>p1=str1;
>while(*p1)
おめでとう。かなり高い確率でバッファオーバーランを実現だ。
mainで確保している【未初期化のbun3】から'\0'が見つかるまで突っ走るぜ!!
俺様を止められるのはOSによる強制停止だげだぜ!ヒッハー!!
ローカル変数はちゃんと初期化しましょうね。
あと、変数名はもう少し気を遣いましょうね。
>while(*p1)
>{
> *p3=*p1;
> p1++;
> p3++;
>}
未初期化のbun3の内容を
>printf("文字列1を入力してください\n"); gets(bun1);
で入力したbun1に対して上書きしていくコードです。
変数名をよ~~っく確認してください。
# char *my_stract(char *str3, char *str2, char *str1)
# の並びで第1引数の変数名が「str3」となっている辺りから誤解がスタートするんです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語配列の結合についてです。 なぜうまくいかないのでしょうか。 #include <stdio.h 4 2022/05/30 22:42
- C言語・C++・C# 宣言する関数の形が決まっている状態で、 str1とstr2の文字列をこの順に引っ付けてstrに保存し 2 2022/05/30 18:21
- C言語・C++・C# c言語でユーザ関数を利用して入力された文字列を反転させるプログラムを作りたいです。 3 2023/01/29 19:47
- C言語・C++・C# バイナリファイルをコピーするのにかかる時間を測りたいのですが実行するとFatel error:gli 2 2022/11/03 01:10
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- C言語・C++・C# 【C言語】全角文字の配列を、全角のまま1文字ずつ出力する方法 4 2023/05/09 15:08
- C言語・C++・C# C言語で再起関数とポインタを用いて文字列反転をする方法がわかりません。 4 2023/04/29 20:32
- C言語・C++・C# str[j++]の意味 2 2022/08/30 16:20
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
小数点入りの文字列をfloat型に...
-
C言語にて構造体のメンバがNULL...
-
char*を初期化したいのですが
-
csvファイルをfscanfで読み込む...
-
ポインタ配列
-
const char* s1とただのchar s1...
-
fread()関数とfwrite()関数につ...
-
ポインタを使って回文かどうか...
-
'\\0'とはなんですか?
-
c言語でポインタ変数を用いた配...
-
strcat関数を自作したいです
-
char 文字列型 の表現範囲が-12...
-
Run-Timeエラーの原因に関して...
-
ASCIIコードへの変換方法
-
VC++6.0にて、文字列処理にて困...
-
fstream型オブジェクトを関数の...
-
charポインタへの文字列による...
-
char AA[]{"全角文字"};から"全...
-
C言語のintとcharの違いってな...
-
CStringからchar*への型変換に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C言語のintとcharの違いってな...
-
char*を初期化したいのですが
-
C言語にて構造体のメンバがNULL...
-
CStringからchar*への型変換に...
-
strcat関数を自作したいです
-
new charとnew char[N]の違いは?
-
csvファイルをfscanfで読み込む...
-
char型にint型の数値を代入する。
-
動的メモリの初期化方法について。
-
C言語で文字列をかえす正しい書...
-
文字列str内の全ての数字を...
-
char 文字列型 の表現範囲が-12...
-
DWORDとcharの変換
-
fstream型オブジェクトを関数の...
-
小数点入りの文字列をfloat型に...
-
C言語のプログラムについてです
-
const char* s1とただのchar s1...
-
文字列内の数字削除
-
c言語でポインタ変数を用いた配...
-
szとlpszの違い
おすすめ情報