エスケープシーケンスやWin32APIなどの環境依存なものもOK
そのような質問は必ず環境を書きましょう
半角空白やタブでのインデントはスレに貼ると無くなります
コードを貼れる所
http://codepad.org/
https://ideone.com/
前スレ
【初心者歓迎】C/C++室 Ver.105【環境依存OK】
https://mevius.5ch.net/test/read.cgi/tech/1556142878/
探検
【初心者歓迎】C/C++室 Ver.106【環境依存OK】
■ このスレッドは過去ログ倉庫に格納されています
2020/07/13(月) 13:51:48.09ID:WBkWHxcT
271デフォルトの名無しさん
2020/10/24(土) 09:29:17.11ID:kz7Ernxq マジでそれ
答えたくないならスルーすればいいのに余計な事を言うのが害悪
答えたくないならスルーすればいいのに余計な事を言うのが害悪
272デフォルトの名無しさん
2020/10/24(土) 09:38:28.92ID:hkdVUCy1273デフォルトの名無しさん
2020/10/24(土) 10:35:52.36ID:Uy2SF5SV >>272
まあ仮想関数使って多重継承でいいんじゃね
機能的には必要十分かと
それより設計上の問題として
Polygon : public Area{}
という構造が適切なのかどうなのか疑問
分かりやすさとしては
Rectangle : public Polygon{},Triangle: public Polygon{}・・・
という単なる形状のみの継承クラスと
Graph {Polygon poly; int area();・・・}
という別の目的で機能するクラスに分けたほうが整理されてる気がする
まあ仮想関数使って多重継承でいいんじゃね
機能的には必要十分かと
それより設計上の問題として
Polygon : public Area{}
という構造が適切なのかどうなのか疑問
分かりやすさとしては
Rectangle : public Polygon{},Triangle: public Polygon{}・・・
という単なる形状のみの継承クラスと
Graph {Polygon poly; int area();・・・}
という別の目的で機能するクラスに分けたほうが整理されてる気がする
274デフォルトの名無しさん
2020/10/24(土) 11:55:33.45ID:yf0wmlMH >>272
制約を付けなくてもテンプレートを展開してダメだったらエラーになることは保証される。
まあ当たり前っていうかそうせざるを得ないもんね。
でも「(制約を満たさないので) マッチに失敗した」と「マッチして展開した結果にエラーがあった」は意味が違っていて、
結果的に失敗させることを意図するならなるべく前者で失敗させた方が使い勝手はいい。
制約を付けなくてもテンプレートを展開してダメだったらエラーになることは保証される。
まあ当たり前っていうかそうせざるを得ないもんね。
でも「(制約を満たさないので) マッチに失敗した」と「マッチして展開した結果にエラーがあった」は意味が違っていて、
結果的に失敗させることを意図するならなるべく前者で失敗させた方が使い勝手はいい。
275デフォルトの名無しさん
2020/10/24(土) 15:57:20.05ID:XyBgTLH4 答えたくなきゃ答えなきゃいいし
余計な事を言いたきゃ言えばいいよ
ここをどこだと思ってんだよw
余計な事を言いたきゃ言えばいいよ
ここをどこだと思ってんだよw
276デフォルトの名無しさん
2020/10/24(土) 22:10:51.67ID:8e/eI8m7 初心者歓迎のスレで初心者叩くなら出てけよ
277デフォルトの名無しさん
2020/10/25(日) 08:54:37.38ID:63196X63278デフォルトの名無しさん
2020/10/25(日) 09:14:07.10ID:xLKzpL4F >>276
初心者で一括りにしたら「やる気のある」初心者に失礼
初心者で一括りにしたら「やる気のある」初心者に失礼
279デフォルトの名無しさん
2020/10/25(日) 11:23:24.95ID:L6mzxwj8280デフォルトの名無しさん
2020/10/25(日) 11:49:00.98ID:KvAimzX1281デフォルトの名無しさん
2020/10/25(日) 18:00:47.89ID:+b3TKvfL リンカーの話とかもここでおkですか? とりあえずlinux系で、
動的ライブラリlibA.soが、別のライブラりlibB.soに依存しているときには,
libA.so作成時、libA.soにlibB.soをリンクしておけば依存性が解決されますよね?
(libA.soを使うプログラム作成時には、libA.soだけ指定すればよい)
諸般の事情で静的ライブラリlibC.aがあり、これがlibD.soに依存するのですが、
この場合、libC.aにlibD.soをリンクしてlibC.aを生成することはできない? ですか?
libD.soは、libC.aを使ったプログラムの作成時にリンク、ということでおkですかね?
これが正解だと、静的と動的で依存性を解決する場所(?)が違うんだなあと。
動的ライブラリlibA.soが、別のライブラりlibB.soに依存しているときには,
libA.so作成時、libA.soにlibB.soをリンクしておけば依存性が解決されますよね?
(libA.soを使うプログラム作成時には、libA.soだけ指定すればよい)
諸般の事情で静的ライブラリlibC.aがあり、これがlibD.soに依存するのですが、
この場合、libC.aにlibD.soをリンクしてlibC.aを生成することはできない? ですか?
libD.soは、libC.aを使ったプログラムの作成時にリンク、ということでおkですかね?
これが正解だと、静的と動的で依存性を解決する場所(?)が違うんだなあと。
282デフォルトの名無しさん
2020/10/25(日) 19:43:38.96ID:+b3TKvfL ふと思いましたが、前者の場合、libA.soにあえてlibB.soをリンクしないで生成、
プログラムにlibA.soをリンクするときにlibB.soを指定する方法もありますよね。
そうすると依存性的には静的ライブラリと同じになる。
でも普通はあえてそんなリンクにはしないのかな。
プログラムにlibA.soをリンクするときにlibB.soを指定する方法もありますよね。
そうすると依存性的には静的ライブラリと同じになる。
でも普通はあえてそんなリンクにはしないのかな。
283デフォルトの名無しさん
2020/10/26(月) 15:01:51.11ID:EltRWJ/H libD.a は行方不明か?
284デフォルトの名無しさん
2020/10/26(月) 19:57:11.86ID:VqHD0zGV しらない🤢
285デフォルトの名無しさん
2020/10/26(月) 20:00:25.63ID:I34qBQJ0 ビタミンCならない
286デフォルトの名無しさん
2020/10/27(火) 05:52:06.98ID:Ol1QMSD8 http://codepad.org/qCDIHh55
https://ideone.com/uTuF1W
上二つは正常に見えます
ところが
https://ideone.com/lWvw1n
暴走しますω
なぜでしょう?
https://ideone.com/uTuF1W
上二つは正常に見えます
ところが
https://ideone.com/lWvw1n
暴走しますω
なぜでしょう?
287デフォルトの名無しさん
2020/10/27(火) 08:29:34.74ID:GDxeid4H virtual int d(){cout<<"Ad\n";}
にreturn文ないのが未定義動作でその時の振る舞いはコンパイラの実装依存なのかな
virtual int d(){cout<<"Ad\n";return 0;}
で正常に動いた
にreturn文ないのが未定義動作でその時の振る舞いはコンパイラの実装依存なのかな
virtual int d(){cout<<"Ad\n";return 0;}
で正常に動いた
288デフォルトの名無しさん
2020/10/27(火) 08:37:11.64ID:GDxeid4H ていうかなんでこの手のコンパイルが通るようになってるんだろうね
そっちが気になるわ
そっちが気になるわ
289デフォルトの名無しさん
2020/10/27(火) 08:56:02.30ID:+sRGEqV1 gcc のバグ?それとも ideone のバグ?
290デフォルトの名無しさん
2020/10/27(火) 09:14:57.09ID:vtWjbkRe http://codepad.org/qCDIHh55
の件で
delete b; は B:d, ~B, A:d, ~A と呼ばれる様ですが
virtual int d() はポリモフィズムで
B:d, ~B, B:d, ~A と呼ばれるのが正しい気がするのですが
デストラクタ内から呼ばれるときは特別なのでしょうか?
の件で
delete b; は B:d, ~B, A:d, ~A と呼ばれる様ですが
virtual int d() はポリモフィズムで
B:d, ~B, B:d, ~A と呼ばれるのが正しい気がするのですが
デストラクタ内から呼ばれるときは特別なのでしょうか?
291デフォルトの名無しさん
2020/10/27(火) 09:57:24.74ID:vyVElDGQ >>282
libD.aはないですw libD.soです。
なんというか、静的リンクって面倒だっなって思ったのと、自分の認識が正しいかを
確認したかったのですが。
プログラムにlibA.soをリンクするときは、libA.soだけ指定すればいい。llibB.soの依存性は
リンカーが解決してくれる(libA.soにlibB.soがリンクされているので)。
一方プログラムにlibC.aをリンクするときは、libD.soも指定しないとlibD.so内の関数が
見つからないエラーになる。かといってlibA.soのように依存するライブラリーを前もって
リンクしておくわけにはいかない。
で正しいですよね?
libD.aはないですw libD.soです。
なんというか、静的リンクって面倒だっなって思ったのと、自分の認識が正しいかを
確認したかったのですが。
プログラムにlibA.soをリンクするときは、libA.soだけ指定すればいい。llibB.soの依存性は
リンカーが解決してくれる(libA.soにlibB.soがリンクされているので)。
一方プログラムにlibC.aをリンクするときは、libD.soも指定しないとlibD.so内の関数が
見つからないエラーになる。かといってlibA.soのように依存するライブラリーを前もって
リンクしておくわけにはいかない。
で正しいですよね?
292デフォルトの名無しさん
2020/10/27(火) 10:09:47.62ID:iKqDwwUH ~B の後 ポリモフィズムで実体のない B:d() を呼び出すのは微妙な感じ
B:d() 内部で Bにまつわるメンバを操作を考えると
すでに生命期間切れてるのにアクセスすることにもなる
B:d() 内部で Bにまつわるメンバを操作を考えると
すでに生命期間切れてるのにアクセスすることにもなる
293デフォルトの名無しさん
2020/10/27(火) 10:11:51.64ID:telUcSp6 違いますよ?
294デフォルトの名無しさん
2020/10/27(火) 10:42:51.63ID:oh18ycKo >>290
コンストラクタ、デストラクタ内では仮想関数はオーバーライド解決されない、ポリモーフィズムは効かないとはっきり決まっておる。
コンストラクタ、デストラクタ内では仮想関数はオーバーライド解決されない、ポリモーフィズムは効かないとはっきり決まっておる。
295はちみつ餃子 ◆8X2XSCHEME
2020/10/27(火) 10:47:51.31ID:0uVZsG3C296デフォルトの名無しさん
2020/10/27(火) 11:47:49.35ID:telUcSp6 はちみつはいつもずれてるな
297はちみつ餃子 ◆8X2XSCHEME
2020/10/27(火) 12:05:37.93ID:TGoBbK5n そうか。
298デフォルトの名無しさん
2020/10/27(火) 13:39:09.37ID:GDxeid4H ~B::B()の内部で~A::A()が呼び出しされてるだけだから
B::d() -> B::~B() -> A::d() -> A::~A()
で正しいんじゃないの~A::A()を普通に呼び出して
B::d()が呼ばれたら怖くない?
B::d() -> B::~B() -> A::d() -> A::~A()
で正しいんじゃないの~A::A()を普通に呼び出して
B::d()が呼ばれたら怖くない?
299デフォルトの名無しさん
2020/10/27(火) 14:47:50.22ID:telUcSp6 いくつかのクラス (A, B, C) をまとめて class X に対して friend にしたいとき
class X 内で
friend A, B, C;
と描くとエラーになります
friend A;
friend B;
friend C;
と描くしかないですか?
あと前方参照のために
class A, B, C;
みたいに並べるのもだめっぽいのですが
他に良い描きかたあるんですか?
class X 内で
friend A, B, C;
と描くとエラーになります
friend A;
friend B;
friend C;
と描くしかないですか?
あと前方参照のために
class A, B, C;
みたいに並べるのもだめっぽいのですが
他に良い描きかたあるんですか?
300デフォルトの名無しさん
2020/10/27(火) 15:08:50.29ID:GuZfhw+Q なぜ後者を良くない書き方だと思った?
その書き方で良いじゃん
その書き方で良いじゃん
301デフォルトの名無しさん
2020/10/28(水) 09:57:07.45ID:Mf8tEr2f302デフォルトの名無しさん
2020/10/28(水) 10:12:29.14ID:3yQQm3er 僕は友達いないのですがfriend 0(;´Д⊂)と書くべきでしょうか?
303デフォルトの名無しさん
2020/10/28(水) 10:35:22.84ID:H1XGsoVq 0は識別子にできないので0にすら見離されてるな
304デフォルトの名無しさん
2020/10/28(水) 11:08:09.05ID:d52OC3St305デフォルトの名無しさん
2020/10/28(水) 11:38:33.08ID:Mf8tEr2f こんなこといいな出来たらいいな
#define A(X, Y, ...) X Y ; A(X, __VA_ARGS__)
A(class, hoge, fuga, hage)
A(friend, hoge, fuga, hage)
#define A(X, Y, ...) X Y ; A(X, __VA_ARGS__)
A(class, hoge, fuga, hage)
A(friend, hoge, fuga, hage)
306デフォルトの名無しさん
2020/10/28(水) 16:32:57.81ID:m1O3OoyR >>305
念のため言っとくけど俺はhageじゃないからな
念のため言っとくけど俺はhageじゃないからな
307デフォルトの名無しさん
2020/10/28(水) 16:47:05.58ID:Gcn0+siH じゃなかったとしても気にしてるのはわかった
308デフォルトの名無しさん
2020/10/28(水) 17:31:58.18ID:3yQQm3er piyoにしてくれ…
309デフォルトの名無しさん
2020/10/28(水) 19:02:09.12ID:wsDCwUN2 友達がいないからハゲなのか
ハゲだから友達がいないのか
ハゲだから友達がいないのか
310デフォルトの名無しさん
2020/10/28(水) 19:07:42.92ID:URI3IFfr ボクはgrault!
311デフォルトの名無しさん
2020/10/29(木) 09:41:00.08ID:RChHWwPC312デフォルトの名無しさん
2020/10/29(木) 12:02:39.93ID:NknHXEaX 下記のようにvectorに追加するときにemplace_backを使って初期値を入れるにはどうすればよいでしょうか?
typedef struct aaa_{
char name; // charもしくはstd::stringでも可
uint64_t count;
} aaa;
std::vector<aaa> v_aaa;
char temp[] = "hoge";
// v_aaaの末尾に初期値を入れて追加。イメージ
v_aaa.emplace_back( aaa({name=temp, count=5}) )
typedef struct aaa_{
char name; // charもしくはstd::stringでも可
uint64_t count;
} aaa;
std::vector<aaa> v_aaa;
char temp[] = "hoge";
// v_aaaの末尾に初期値を入れて追加。イメージ
v_aaa.emplace_back( aaa({name=temp, count=5}) )
313デフォルトの名無しさん
2020/10/29(木) 12:11:31.88ID:5Qrr6OP3314デフォルトの名無しさん
2020/10/29(木) 12:11:50.37ID:9V9XS1Y8 無理じゃね?
structにコンストラクタを用意する訳にはいかんの?
structにコンストラクタを用意する訳にはいかんの?
315はちみつ餃子 ◆8X2XSCHEME
2020/10/29(木) 15:34:56.14ID:WswsrqDV316デフォルトの名無しさん
2020/10/29(木) 15:38:32.83ID:C1ySRMXt 暗黙のコピーコンストラクタか…
emplace_backの意味ねー
emplace_backの意味ねー
317はちみつ餃子 ◆8X2XSCHEME
2020/10/29(木) 16:06:03.93ID:WswsrqDV 引数を受け取るところでも RVO の適用対象になるから余計なコピーはたぶんそんなに起こらないはずだと思う。
(ちゃんと検証してないので間違ってたらごめん。)
(ちゃんと検証してないので間違ってたらごめん。)
318デフォルトの名無しさん
2020/10/29(木) 20:07:08.57ID:rufTpjFS push_backでいいじゃん
319デフォルトの名無しさん
2020/10/29(木) 23:17:56.41ID:BMEZnPdC320デフォルトの名無しさん
2020/10/29(木) 23:30:45.17ID:BMEZnPdC もう一つ質問です。
uint16_t num;
std::string str;
という2つの変数があった時、strを数値変換してnumに入れたいのですが、下記はどちらも間違ってはないですか?
どちらも戻り値はintとあったのですが、uint16で受けても問題ないのでしょうか?
num = std::stoi(str);
num = atoi(str.c_str());
uint16_t num;
std::string str;
という2つの変数があった時、strを数値変換してnumに入れたいのですが、下記はどちらも間違ってはないですか?
どちらも戻り値はintとあったのですが、uint16で受けても問題ないのでしょうか?
num = std::stoi(str);
num = atoi(str.c_str());
321デフォルトの名無しさん
2020/10/30(金) 00:49:26.28ID:XnkdHuuj 問題があるかどうかはstrの仕様次第
uint16_tの範囲外があり得ないなら大丈夫、あり得るなら勿論ダメ
今時のコンパイラなら大きいものから小さいものへの暗黙の変換には警告が出る
警告消したいなら明示castして
uint16_tの範囲外があり得ないなら大丈夫、あり得るなら勿論ダメ
今時のコンパイラなら大きいものから小さいものへの暗黙の変換には警告が出る
警告消したいなら明示castして
322はちみつ餃子 ◆8X2XSCHEME
2020/10/30(金) 09:22:29.76ID:WoJDazC2 >>320
int から uint16_t の変換について
変換後の型で表せない範囲の値を変換しようとしたとき、変換後の型が符号なし整数型である場合には、
変換後の型が格納可能な最大値 + 1 で modulo を取った値になることになってる。
(変換後の型が符号付である場合には未定義。)
結果の大きさが確実に uint16_t の範囲に入るという確信がある状況であればもちろん問題ないし、
そうでないときも結果が未定義ではないという意味では問題ないが、
プログラムの意図に合致するかどうかは状況による。
----
文字列を数値に変換することについて、
atoi はエラーハンドリングがちゃんとできない (変換に失敗したら 0 を返すが変換結果が 0 のときと区別できない) ので、
事前に文字列の検証が済んでいるのでなければ stoi の方が好ましくはある。
int から uint16_t の変換について
変換後の型で表せない範囲の値を変換しようとしたとき、変換後の型が符号なし整数型である場合には、
変換後の型が格納可能な最大値 + 1 で modulo を取った値になることになってる。
(変換後の型が符号付である場合には未定義。)
結果の大きさが確実に uint16_t の範囲に入るという確信がある状況であればもちろん問題ないし、
そうでないときも結果が未定義ではないという意味では問題ないが、
プログラムの意図に合致するかどうかは状況による。
----
文字列を数値に変換することについて、
atoi はエラーハンドリングがちゃんとできない (変換に失敗したら 0 を返すが変換結果が 0 のときと区別できない) ので、
事前に文字列の検証が済んでいるのでなければ stoi の方が好ましくはある。
323デフォルトの名無しさん
2020/10/30(金) 09:49:07.73ID:7Hoin+z3 >>322
https://timsong-cpp.github.io/cppwp/n4659/conv.integral#3
> If the destination type is signed, the value is unchanged if it can be represented in the destination type; otherwise, the value is implementation-defined.
未定義ではないね。移植性は損なわれるけど。
https://timsong-cpp.github.io/cppwp/n4659/conv.integral#3
> If the destination type is signed, the value is unchanged if it can be represented in the destination type; otherwise, the value is implementation-defined.
未定義ではないね。移植性は損なわれるけど。
324デフォルトの名無しさん
2020/10/30(金) 11:26:35.44ID:7MkyV1Cp >>322
>変換後の型で表せない範囲の値を変換しようとしたとき、変換後の型が符号なし整数型である場合には、
>変換後の型が格納可能な最大値 + 1 で modulo を取った値になることになってる。
>(変換後の型が符号付である場合には未定義。)
結果的にそうなってるだけで実際は上位bit(byte)棄ててるだけじゃないの
>変換後の型で表せない範囲の値を変換しようとしたとき、変換後の型が符号なし整数型である場合には、
>変換後の型が格納可能な最大値 + 1 で modulo を取った値になることになってる。
>(変換後の型が符号付である場合には未定義。)
結果的にそうなってるだけで実際は上位bit(byte)棄ててるだけじゃないの
325デフォルトの名無しさん
2020/10/30(金) 12:42:27.15ID:Avmc/4l5326はちみつ餃子 ◆8X2XSCHEME
2020/10/30(金) 13:29:46.50ID:WoJDazC2327はちみつ餃子 ◆8X2XSCHEME
2020/10/30(金) 13:31:26.19ID:WoJDazC2 >>325
1 の補数を使っているときにマイナスの値が絡んでくるとちょっと調整が必要になるんじゃね?
1 の補数を使っているときにマイナスの値が絡んでくるとちょっと調整が必要になるんじゃね?
328デフォルトの名無しさん
2020/10/30(金) 14:26:56.09ID:NkdFBoQj stoiとか" -1"とか食わせると-1のintになるんでしょ
parserとかゴリゴリ実装してんのかね
parserとかゴリゴリ実装してんのかね
329はちみつ餃子 ◆8X2XSCHEME
2020/10/30(金) 14:36:46.44ID:WoJDazC2 >>328
扱えるのは整数だけだし、マイナスの他には 0 か 0x が付く場合を処理できればいいのでそんなに複雑ではないと思う。
扱えるのは整数だけだし、マイナスの他には 0 か 0x が付く場合を処理できればいいのでそんなに複雑ではないと思う。
330デフォルトの名無しさん
2020/10/30(金) 14:48:32.14ID:NkdFBoQj なるほどね
331デフォルトの名無しさん
2020/10/31(土) 22:42:02.96ID:R+EB1+ZF https://ideone.com/o3N4x1
上記の44行目の「ここから〜」と70行目の「ここまで」の部分で変数p_aaa、p_bbbのstr変数を書き換えるという同等の処理をしているのですが、
実際のここの部分は何十行もあるので、メンテナンス性を良くするために、この共通部分を共有できないかと考えています。
関数化すればと思いましたが、引数の構造体が別物のため関数化できません。
何か方法はありますでしょうか?
上記の44行目の「ここから〜」と70行目の「ここまで」の部分で変数p_aaa、p_bbbのstr変数を書き換えるという同等の処理をしているのですが、
実際のここの部分は何十行もあるので、メンテナンス性を良くするために、この共通部分を共有できないかと考えています。
関数化すればと思いましたが、引数の構造体が別物のため関数化できません。
何か方法はありますでしょうか?
332デフォルトの名無しさん
2020/10/31(土) 22:51:08.31ID:u29GL2G8 unsigned char* common(unsigned char* arg)
{
{
333デフォルトの名無しさん
2020/10/31(土) 22:54:20.54ID:u29GL2G8 送信しちゃった
unsigned char* を受けて realloc し、 reallocの戻りの [9][10][11] を書き込みしつつ
reallocの戻りを返す (失敗は exit) そういう関数 common() で
p_aaa->str = common(p_aaa->str);
p_bbb->str = common(p_bbb->str);
こうまとめる感じ
unsigned char* を受けて realloc し、 reallocの戻りの [9][10][11] を書き込みしつつ
reallocの戻りを返す (失敗は exit) そういう関数 common() で
p_aaa->str = common(p_aaa->str);
p_bbb->str = common(p_bbb->str);
こうまとめる感じ
334デフォルトの名無しさん
2020/10/31(土) 23:03:36.76ID:u29GL2G8 ideone のコードがあくまで str の操作に終始してるので >>333 になる
共通のコードが type についても同じ操作するのなら
str, type だけを単発の構造体 BASE にして AAA, BBB は BASE を継承しておく
で、関数は BASE を受ける(必要なら BASE を返す or 参照渡しで書き換え)
共通のコードが type についても同じ操作するのなら
str, type だけを単発の構造体 BASE にして AAA, BBB は BASE を継承しておく
で、関数は BASE を受ける(必要なら BASE を返す or 参照渡しで書き換え)
335デフォルトの名無しさん
2020/10/31(土) 23:18:42.13ID:3iDylFBH offsetofで距離の値をメタ取得しメンバアクセスでなく剥いでchar*にすればいいと思うよ
336デフォルトの名無しさん
2020/11/01(日) 10:32:39.62ID:6FKS57jf >>331
テンプレート関数を使って、コードの上では一つの関数に見せかけておくようにする
前準備の箇所も同様
hsgAWF - Online C++0x Compiler & Debugging Tool - Ideone.com
https://ideone.com/hsgAWF
テンプレート関数を使って、コードの上では一つの関数に見せかけておくようにする
前準備の箇所も同様
hsgAWF - Online C++0x Compiler & Debugging Tool - Ideone.com
https://ideone.com/hsgAWF
337デフォルトの名無しさん
2020/11/01(日) 11:12:58.96ID:tm2facI/338331
2020/11/01(日) 11:33:12.85ID:caGW9eb5 >>334
関数にp_aaa->strを渡して値の書き換えを考えたのですが、関数内のreallocでアドレス変わるからその値を変えてもだめだ。
って思っていました。
ご提案の通りアドレス変わったものを戻り値で返してあげればいいですね。
その考えが抜けていました。
>>335
すみません、剥いでchar*にすればいいってところがよくわかりませんでした。。
>>336
今回以外のケースでも使いみちありそうなのでテンプレートについて調べてみました。
関数やclassを定義する先頭に<typename T, typename HOGE>のように可変できる独自の型を作れる。
関数、クラス使用時に関数名のあとに<unsigned char*, int>のように型を指定する。
という理解であってますか?
関数にp_aaa->strを渡して値の書き換えを考えたのですが、関数内のreallocでアドレス変わるからその値を変えてもだめだ。
って思っていました。
ご提案の通りアドレス変わったものを戻り値で返してあげればいいですね。
その考えが抜けていました。
>>335
すみません、剥いでchar*にすればいいってところがよくわかりませんでした。。
>>336
今回以外のケースでも使いみちありそうなのでテンプレートについて調べてみました。
関数やclassを定義する先頭に<typename T, typename HOGE>のように可変できる独自の型を作れる。
関数、クラス使用時に関数名のあとに<unsigned char*, int>のように型を指定する。
という理解であってますか?
339デフォルトの名無しさん
2020/11/01(日) 11:33:14.25ID:tm2facI/ 呪縛から逃れられないでござる
http://codepad.org/jA1YoG7E
http://codepad.org/jA1YoG7E
340デフォルトの名無しさん
2020/11/01(日) 11:40:17.79ID:6FKS57jf >>338
テンプレートはだいたいそのようなもの
テンプレートはだいたいそのようなもの
341デフォルトの名無しさん
2020/11/01(日) 13:11:03.10ID:BdB3gM+x こんな感じで定義したいときどうすればいい?
template <X>
class X {
public:
X() {}
~X() {}
};
template <X>
class X {
public:
X() {}
~X() {}
};
343デフォルトの名無しさん
2020/11/01(日) 14:07:18.93ID:BdB3gM+x >>342
template <class X>
class A {
X *x;
public:
A(X *a) : x(a) {}
~A(){}
};
int x = 1;
A<int> a(&x);
A<A> b(new A<int>(&x)); ←ここエラー
こういうときに
class A {
A *x;
public:
A(A *a) : x(a) {}
~A(){}
};
みたいな A とよく似た B C D ... があるとき
template <class X>
class X {
X *x;
public:
X(X *a) : x(a) {}
~X(){}
};
って描けると便利かなと思いました
template <class X>
class A {
X *x;
public:
A(X *a) : x(a) {}
~A(){}
};
int x = 1;
A<int> a(&x);
A<A> b(new A<int>(&x)); ←ここエラー
こういうときに
class A {
A *x;
public:
A(A *a) : x(a) {}
~A(){}
};
みたいな A とよく似た B C D ... があるとき
template <class X>
class X {
X *x;
public:
X(X *a) : x(a) {}
~X(){}
};
って描けると便利かなと思いました
344はちみつ餃子 ◆8X2XSCHEME
2020/11/01(日) 14:14:48.71ID:JHJcVuLz345デフォルトの名無しさん
2020/11/01(日) 14:15:42.25ID:22aX9WTF >>343
> A<A> b(new A<int>(&x)); ←ここエラー
その記述(特に A<A> という型)でどんな結果を期待していたのかわからない。
> みたいな A とよく似た B C D ... があるとき
A と B は何が違うのか(なぜ A ひとつではダメなのか)わからない。
> A<A> b(new A<int>(&x)); ←ここエラー
その記述(特に A<A> という型)でどんな結果を期待していたのかわからない。
> みたいな A とよく似た B C D ... があるとき
A と B は何が違うのか(なぜ A ひとつではダメなのか)わからない。
346デフォルトの名無しさん
2020/11/01(日) 14:28:09.77ID:BdB3gM+x >>345
>その記述(特に A<A> という型)でどんな結果を期待していたのかわからない。
class A {
A *x;
public:
A(A *a) : x(a) {}
~A(){}
};
です
>A と B は何が違うのか(なぜ A ひとつではダメなのか)わからない。
上の例だと最小限にしたつもりなので差が無くなってしまってますが
実際は template <class X, class Y> みたいにして Y が違う感じです
>その記述(特に A<A> という型)でどんな結果を期待していたのかわからない。
class A {
A *x;
public:
A(A *a) : x(a) {}
~A(){}
};
です
>A と B は何が違うのか(なぜ A ひとつではダメなのか)わからない。
上の例だと最小限にしたつもりなので差が無くなってしまってますが
実際は template <class X, class Y> みたいにして Y が違う感じです
347デフォルトの名無しさん
2020/11/01(日) 15:25:26.50ID:QwbHyU2z 幼女が身振り手振り一生懸命しつもんしてると思うと萌えてくるな
348デフォルトの名無しさん
2020/11/01(日) 15:35:14.35ID:CKi2+wqr 母娘丼が好きです
349デフォルトの名無しさん
2020/11/01(日) 16:29:24.33ID:22aX9WTF >>346
ごめんさっぱり見えてこないや。「最小限にしたつもり」で情報削りすぎてるんだろうな。
質問の基本として、望む結果、そのために書いたコード、実際の(望ましくない)結果、あたりはそろえてもらわないと
うまくお話しできない。
ごめんさっぱり見えてこないや。「最小限にしたつもり」で情報削りすぎてるんだろうな。
質問の基本として、望む結果、そのために書いたコード、実際の(望ましくない)結果、あたりはそろえてもらわないと
うまくお話しできない。
350331
2020/11/01(日) 19:17:22.75ID:tQIBnCrw >>340
ありがとうございます。勉強になりました。
ついでに追加で質問があります。
最初に投稿したコード →https://ideone.com/o3N4x1
の36〜37行目で値と0x00を入れるのに2行使ってますが、これ以上簡素化はできないですよね?
36: memcpy(p_bbb->str, bbb_str_temp, 9);
37: p_bbb->str[9] = 0x00;
あと54〜56行では3行に分けて1バイトづつセットしてますが、ここを一気に入れる方法はありませんか?
イメージは21行目のcharを初期化するときのように {0x41, 0x41, 0x00} みたいな書き方ができないかなと思っているのですが。
54: p_aaa->str[9] = 0x41;
55: p_aaa->str[10] = 0x41;
56: p_aaa->str[11] = 0x00;
ありがとうございます。勉強になりました。
ついでに追加で質問があります。
最初に投稿したコード →https://ideone.com/o3N4x1
の36〜37行目で値と0x00を入れるのに2行使ってますが、これ以上簡素化はできないですよね?
36: memcpy(p_bbb->str, bbb_str_temp, 9);
37: p_bbb->str[9] = 0x00;
あと54〜56行では3行に分けて1バイトづつセットしてますが、ここを一気に入れる方法はありませんか?
イメージは21行目のcharを初期化するときのように {0x41, 0x41, 0x00} みたいな書き方ができないかなと思っているのですが。
54: p_aaa->str[9] = 0x41;
55: p_aaa->str[10] = 0x41;
56: p_aaa->str[11] = 0x00;
351デフォルトの名無しさん
2020/11/01(日) 21:33:20.20ID:6FKS57jf >>350
こんなんになるんだろうか
lnDOFG - Online C++0x Compiler & Debugging Tool - Ideone.com
https://ideone.com/lnDOFG
Cプログラミング診断室/珠玉の力作/文字列処理
http://www.pro.or.jp/~fuji/mybooks/cdiag/cdiag.9.3.html
こんなんになるんだろうか
lnDOFG - Online C++0x Compiler & Debugging Tool - Ideone.com
https://ideone.com/lnDOFG
Cプログラミング診断室/珠玉の力作/文字列処理
http://www.pro.or.jp/~fuji/mybooks/cdiag/cdiag.9.3.html
352デフォルトの名無しさん
2020/11/02(月) 16:50:10.64ID:P+uwjz0Z >>346が言ってるのは多分、テンプレート引数によって異なる識別子のクラスを定義したいってことじゃね?
それは型の次元じゃなくて識別子の次元だからプリプロセッサでやるしかないと思うが
それは型の次元じゃなくて識別子の次元だからプリプロセッサでやるしかないと思うが
353デフォルトの名無しさん
2020/11/02(月) 17:19:37.51ID:gwxuwnSp と思ったけどよく読むとなんか違うっぽいな・・すまん
355デフォルトの名無しさん
2020/11/05(木) 02:53:59.36ID:CsR+UXSo c++14のconstexpr変数について質問です
constexpr変数は内部リンケージですので、グローバル定数をconstexpr変数で作ろうとすると複数の翻訳単位で実態が作成されてしまうと思います
c++17ではinline変数とすることでただ一つの実態を指すようにできますが、c++14ではどのようにすればよいのでしょうか?
コンパイラがよしなにしてくれますか?
constexpr変数は内部リンケージですので、グローバル定数をconstexpr変数で作ろうとすると複数の翻訳単位で実態が作成されてしまうと思います
c++17ではinline変数とすることでただ一つの実態を指すようにできますが、c++14ではどのようにすればよいのでしょうか?
コンパイラがよしなにしてくれますか?
356デフォルトの名無しさん
2020/11/05(木) 13:17:18.71ID:gh/oj34p static constexpr
で後は良きに計らってもらえ。
で後は良きに計らってもらえ。
357デフォルトの名無しさん
2020/11/07(土) 10:44:01.28ID:PF2b8VJJ >>350
ちょい亀だが、興味あったんで調べてみた。
自分の趣味的には可変引数テンプレートを使ってバイト列にダラダラ書き足していく
感じかな?対応関数増やせばいろんな型をバイト列に展開しやすい。
my_append(&p_aaa->str[9], &p_aaa->str[12], 0x41, 0x42, 0x00);
もう一つは std::initializer_list を使ったもの。リストの1つ目は unsigned char* の
書き出し位置を指定して、あとは int 値の羅列。
参照: ttps://stackoverflow.com/questions/25721869/initializer-list-combined-with-other-parameters
my_append_helper() = { &p_bbb->str[9], 0x41, 0x42, 0 };
ttps://ideone.com/OdbRew
ちょい亀だが、興味あったんで調べてみた。
自分の趣味的には可変引数テンプレートを使ってバイト列にダラダラ書き足していく
感じかな?対応関数増やせばいろんな型をバイト列に展開しやすい。
my_append(&p_aaa->str[9], &p_aaa->str[12], 0x41, 0x42, 0x00);
もう一つは std::initializer_list を使ったもの。リストの1つ目は unsigned char* の
書き出し位置を指定して、あとは int 値の羅列。
参照: ttps://stackoverflow.com/questions/25721869/initializer-list-combined-with-other-parameters
my_append_helper() = { &p_bbb->str[9], 0x41, 0x42, 0 };
ttps://ideone.com/OdbRew
358350
2020/11/07(土) 22:29:19.80ID:CR7v1mZc >>357
サンプルコードありがとうございます。
引数を可変で受け取ることができるんですね。
これ色んなところで使えそうですが、ぱっと見た感じちょっとクセがあって難しいですね。
思考が追いつかない。。
じっくり考えて理解してみます。
サンプルコードありがとうございます。
引数を可変で受け取ることができるんですね。
これ色んなところで使えそうですが、ぱっと見た感じちょっとクセがあって難しいですね。
思考が追いつかない。。
じっくり考えて理解してみます。
359デフォルトの名無しさん
2020/11/08(日) 13:25:53.56ID:M0llHupc float a = 1.234;
float b = 1.234f;
double c = 1.234;
double d = 1.234f;
これらの違いを教えてください
double に 1.234f を使って float に 1.234 を使うのが正しいんでしょうか?
float b = 1.234f;
double c = 1.234;
double d = 1.234f;
これらの違いを教えてください
double に 1.234f を使って float に 1.234 を使うのが正しいんでしょうか?
360デフォルトの名無しさん
2020/11/08(日) 14:18:47.54ID:ahbNcVL+ ゥー
361デフォルトの名無しさん
2020/11/08(日) 15:36:43.95ID:8e1Utdpy >>359
何も付けなければ整数リテラルはint 小数リテラルははdoubleとなる。
つまり
float a = 1.234; doubleをfloatに変換して代入
float b = 1.234f; floatをfloatに代入
double c = 1.234; doubleをdoubleに代入
double d = 1.234f; floatをdoubleに変換して代入
でfloatの値を指定したい時だけfを付ける。
何も付けなければ整数リテラルはint 小数リテラルははdoubleとなる。
つまり
float a = 1.234; doubleをfloatに変換して代入
float b = 1.234f; floatをfloatに代入
double c = 1.234; doubleをdoubleに代入
double d = 1.234f; floatをdoubleに変換して代入
でfloatの値を指定したい時だけfを付ける。
362デフォルトの名無しさん
2020/11/08(日) 15:48:25.65ID:M0llHupc ありがとうございます
float a = 1.234;
これで警告が出ないのは不思議ですね
float a = 1.234;
これで警告が出ないのは不思議ですね
363デフォルトの名無しさん
2020/11/08(日) 16:04:26.00ID:l+XTZ4Mk コンパイラの警告レベルの設定によるんじゃないの
365デフォルトの名無しさん
2020/11/08(日) 16:32:11.23ID:E458/dQk 以下のコンストラクタの書き方は正しいのでしょうか?
Duration(int data) : data_(data), negative_(false) { // メンバ初期化
if (data < 0) { // 条件を満たすとき上書き
data_ *= -1;
negative_ = true;
}
}
Duration(int data) : data_(data), negative_(false) { // メンバ初期化
if (data < 0) { // 条件を満たすとき上書き
data_ *= -1;
negative_ = true;
}
}
366デフォルトの名無しさん
2020/11/08(日) 16:42:03.14ID:1+QGrERy >>365 まずどこが正しくないと思ってるのか言えよ。
367デフォルトの名無しさん
2020/11/08(日) 17:28:50.68ID:E458/dQk Duration(int data)
: data_{data < 0 ? -data : data}
, negative_{data < 0} {}
と書けるのを発見しました。お目汚し失礼しました。
: data_{data < 0 ? -data : data}
, negative_{data < 0} {}
と書けるのを発見しました。お目汚し失礼しました。
368デフォルトの名無しさん
2020/11/08(日) 18:41:53.30ID:p8PLYZoN 下記のようにfor文の外で構造体を参照できるようにするにはどうすればよいですか?
newで生成するとmallocのように寿命が無いオブジェクトを生成できるとネットで見たのですが、そうなりませんでした。。
std::unordered_map<std::string, XXX*> unmap;
for(){
xxx = new XXX ←構造体
map["key"] = xxx; ←構造体のポインタを代入
}
map["key"] ←for文の外でxxxを参照できるようにしたい。
newで生成するとmallocのように寿命が無いオブジェクトを生成できるとネットで見たのですが、そうなりませんでした。。
std::unordered_map<std::string, XXX*> unmap;
for(){
xxx = new XXX ←構造体
map["key"] = xxx; ←構造体のポインタを代入
}
map["key"] ←for文の外でxxxを参照できるようにしたい。
369デフォルトの名無しさん
2020/11/08(日) 19:17:29.56ID:p8PLYZoN 変数名を間違えてるところがあったので訂正します。
std::unordered_map<std::string, XXX*> unmap;
for(){
xxx = new XXX ←構造体
unmap[key] = xxx; ←構造体のポインタを代入
}
unmap[key] ←for文の外でxxxを参照できるようにしたい。
std::unordered_map<std::string, XXX*> unmap;
for(){
xxx = new XXX ←構造体
unmap[key] = xxx; ←構造体のポインタを代入
}
unmap[key] ←for文の外でxxxを参照できるようにしたい。
370デフォルトの名無しさん
2020/11/08(日) 19:27:41.20ID:1+QGrERy >>368-369
書かれたコードを見る限り参照はできそうなので、何を見て参照できないと言っているのかがわからない。
書かれたコードを見る限り参照はできそうなので、何を見て参照できないと言っているのかがわからない。
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【いちご高騰】ヤマザキのクリスマスケーキ、いちご無し販売 [おっさん友の会★]
- ネット殺到「高市総理の責任」「完全に高市リスク」「負けるな」中国が水産物輸入停止→流石に総理批判の声も「どう責任取る?」 ★10 [樽悶★]
- 【日中対立】 朝日新聞のタイトル修正が中国逆ギレの火種か SNSで批判相次ぐ [♪♪♪★]
- 「ドラゴンボール」初の全世界キャラクター人気投票が開幕!212キャラからナンバーワンが決まる!! [ひかり★]
- 【音楽】『日本レコード大賞』各賞発表! 大賞候補にILLIT、M!LK、ふるっぱー、幾田りら、アイナ、ミセスら… 作詩賞は指原莉乃 [冬月記者★]
- 映画史上もっとも“スカッとする”結末の作品5選 [muffin★]
- 【悲報】秋元康「女性アイドルグループはもうオワコン。会いにいける男性アイドルグループを作る」 [455031798]
- ダイエット始めたんだけど500mすら泳ぐの辛い
- 【すべてが】𝗮𝗺͜𝗮͉𝘇𝗼𝗻ブラックフライデーSALE総合【いいだろ!】 [194819832]
- 【高市速報】日本人の3割「中国への武力行使に踏み切る必要がある」ANN世論調査 [931948549]
- ワイ刀オタ、欲しい刀が中々ネットで見つからず咽び泣く
- 【訃報】日経平均先物逝く、円安株安債券安 [943688309]
