※前スレ
C++相談室 part154
https://mevius.5ch.net/test/read.cgi/tech/1610096040/
テンプレここまで
C++相談室 part155
■ このスレッドは過去ログ倉庫に格納されています
2021/03/24(水) 12:07:15.39ID:R+oM8cup
543デフォルトの名無しさん
2021/04/29(木) 08:34:23.25ID:3mmNht9g544デフォルトの名無しさん
2021/04/29(木) 08:51:08.82ID:fshfa4aU 質問者がbegin()とend()の定義の必要性を把握しているのに対して
begin()のみではNGだとレスするのがそんなにドヤるほどのことなのかどうか……
begin()のみではNGだとレスするのがそんなにドヤるほどのことなのかどうか……
545デフォルトの名無しさん
2021/04/29(木) 08:55:45.00ID:3mmNht9g546デフォルトの名無しさん
2021/04/29(木) 09:04:34.25ID:6rdxVFZp >>542
ありがとうございます
v は必ずしも vector<int> ではなく vector<vector<int>> とかで、かついっぱい回るループを想定してるのでできるだけ定数倍を軽くしたいのですが、j を右辺値参照にすればコピーは起きないので相当マシと思って良いですかね
ありがとうございます
v は必ずしも vector<int> ではなく vector<vector<int>> とかで、かついっぱい回るループを想定してるのでできるだけ定数倍を軽くしたいのですが、j を右辺値参照にすればコピーは起きないので相当マシと思って良いですかね
547デフォルトの名無しさん
2021/04/29(木) 09:07:08.51ID:1rAkIDNr 右辺値参照つってもauto&&は左辺値参照も兼ねるぞ
548デフォルトの名無しさん
2021/04/29(木) 09:16:30.33ID:fshfa4aU549デフォルトの名無しさん
2021/04/29(木) 09:22:13.70ID:3mmNht9g 二個目の条件に反してる
550デフォルトの名無しさん
2021/04/29(木) 09:41:24.58ID:fshfa4aU551デフォルトの名無しさん
2021/04/29(木) 10:20:12.63ID:gzXxIopT552デフォルトの名無しさん
2021/04/29(木) 10:26:57.88ID:6rdxVFZp >>547
for()のカッコの中でiをjの参照として定義できたらそれでも良いんですが、そういうことはできるんでしたっけ?
for()のカッコの中でiをjの参照として定義できたらそれでも良いんですが、そういうことはできるんでしたっけ?
553デフォルトの名無しさん
2021/04/29(木) 10:28:45.87ID:6rdxVFZp すみません「定義」というよりは、forのスコープの外にiの宣言はあって、for(ここ)でiがjの参照であることにできたら良いってことです
554デフォルトの名無しさん
2021/04/29(木) 10:29:35.81ID:fshfa4aU555デフォルトの名無しさん
2021/04/29(木) 10:35:45.46ID:gzXxIopT556デフォルトの名無しさん
2021/04/29(木) 11:07:16.11ID:1rAkIDNr557デフォルトの名無しさん
2021/04/29(木) 11:10:24.28ID:6rdxVFZp558デフォルトの名無しさん
2021/04/29(木) 11:52:35.69ID:1rAkIDNr559デフォルトの名無しさん
2021/04/29(木) 12:28:01.48ID:vjsl7cGC ポインタと参照の決定的な違いはそこだね
560デフォルトの名無しさん
2021/04/29(木) 12:46:42.20ID:yUiVUiFp >>541
begin()とend()の型が一致してる必要はない(C++17〜)
begin()とend()の型が一致してる必要はない(C++17〜)
561デフォルトの名無しさん
2021/04/29(木) 13:03:31.68ID:K/HFYMcp https://negation.hatenadiary.org/entry/20111203/1322876171
↑で、簡単に書けば、
class Book {・・・};
class Novel : public Book{・・・};
class Comic : public Book{・・・};
class Shelf { public: std::vector<Book> list; ・・・ };
Shelf g_shelf;
int main(void) {
Novel n = Novel("Hoshio wo tugumono");
Comic c = Comic("Kimetsu no Yaiba");
Shelf s = Shelf();
g_shelft.list.push_back(n);
g_shelft.list.push_back(c);
}
のようになっているところがあるけど、
vector<Book>って、Bookの実体の動的配列で、
Book a[100];
とにら様なものだと思うんだけど、NovelやComicのクラスのバイトサイズが
Bookを越えたら、入りきれないと思うんだけど、これで合ってる?
合ってるとしたら、どういう仕組み?
もしかして、vector<Book>って、
Book *p[100];
みたいな配列なの?
↑で、簡単に書けば、
class Book {・・・};
class Novel : public Book{・・・};
class Comic : public Book{・・・};
class Shelf { public: std::vector<Book> list; ・・・ };
Shelf g_shelf;
int main(void) {
Novel n = Novel("Hoshio wo tugumono");
Comic c = Comic("Kimetsu no Yaiba");
Shelf s = Shelf();
g_shelft.list.push_back(n);
g_shelft.list.push_back(c);
}
のようになっているところがあるけど、
vector<Book>って、Bookの実体の動的配列で、
Book a[100];
とにら様なものだと思うんだけど、NovelやComicのクラスのバイトサイズが
Bookを越えたら、入りきれないと思うんだけど、これで合ってる?
合ってるとしたら、どういう仕組み?
もしかして、vector<Book>って、
Book *p[100];
みたいな配列なの?
562デフォルトの名無しさん
2021/04/29(木) 13:05:10.26ID:K/HFYMcp >>561
すまん。間違った。正しくはこう :
int main(void) {
Novel n = Novel("Hoshio wo tugumono");
Comic c = Comic("Kimetsu no Yaiba");
Shelf s = Shelf();
s.list.push_back(n);
s.list.push_back(c);
}
すまん。間違った。正しくはこう :
int main(void) {
Novel n = Novel("Hoshio wo tugumono");
Comic c = Comic("Kimetsu no Yaiba");
Shelf s = Shelf();
s.list.push_back(n);
s.list.push_back(c);
}
563デフォルトの名無しさん
2021/04/29(木) 13:10:29.61ID:yUiVUiFp564デフォルトの名無しさん
2021/04/29(木) 13:10:34.24ID:K/HFYMcp https://stackoverflow.com/questions/16126578/vectors-and-polymorphism-in-c
↑によれば、やっぱり、>>561 や >>562 のようなやり方は間違いで、
std::vector<T> の T は、Bookではなく、shared_ptr<Book> のようなものを入れるべきで、
以下の様になっている。だから、>>561 や >>562 は間違いだよね?
class Instruction {・・・};
class Add: public Instruction{・・・};
typedef shared_ptr<Instruction> PInstruction;
vector<PInstruction> v;
v.emplace_back(make_shared<Add>());
↑によれば、やっぱり、>>561 や >>562 のようなやり方は間違いで、
std::vector<T> の T は、Bookではなく、shared_ptr<Book> のようなものを入れるべきで、
以下の様になっている。だから、>>561 や >>562 は間違いだよね?
class Instruction {・・・};
class Add: public Instruction{・・・};
typedef shared_ptr<Instruction> PInstruction;
vector<PInstruction> v;
v.emplace_back(make_shared<Add>());
565デフォルトの名無しさん
2021/04/29(木) 13:16:01.96ID:yUiVUiFp566デフォルトの名無しさん
2021/04/29(木) 13:19:09.72ID:K/HFYMcp >>563
なるほど、では、正しい書き方としては、たとえば、こうかな:
class Book {・・・};
class Novel : public Book{・・・};
class Comic : public Book{・・・};
typedef shared_ptr<Book> PBOOK;
class Shelf : public std::vector<PBOOK> {・・・};
Shelf g_shelf;
int main(void) {
std::shared_ptr<Novel> n = make_shared<Novel>("Hoshio wo tugumono");
std::shared_ptr<Comic> c = make_shared<Comic>("Kimetsu no Yaiba");
g_shelf.push_back(n);
g_shelf.push_back(c);
}
なるほど、では、正しい書き方としては、たとえば、こうかな:
class Book {・・・};
class Novel : public Book{・・・};
class Comic : public Book{・・・};
typedef shared_ptr<Book> PBOOK;
class Shelf : public std::vector<PBOOK> {・・・};
Shelf g_shelf;
int main(void) {
std::shared_ptr<Novel> n = make_shared<Novel>("Hoshio wo tugumono");
std::shared_ptr<Comic> c = make_shared<Comic>("Kimetsu no Yaiba");
g_shelf.push_back(n);
g_shelf.push_back(c);
}
567はちみつ餃子 ◆8X2XSCHEME
2021/04/29(木) 18:07:20.75ID:x0Vd7BP9 パブリック継承している型のオブジェクトが基底クラスへ暗黙に型変換されるのは抑止する方法がないんだよな。
568デフォルトの名無しさん
2021/04/30(金) 01:30:09.20ID:7VhEvZ/Q569デフォルトの名無しさん
2021/04/30(金) 08:17:30.86ID:tsrXe0Ut それは別に問題ない
func(Animal a)だとやばい
func(Animal a)だとやばい
570デフォルトの名無しさん
2021/04/30(金) 09:32:28.19ID:W8up1rh0 funcがAnimalの情報しか使わないんなら別にいいんだけどね
単にポリモーフィズムにはポインタか参照が必要ってだけ
単にポリモーフィズムにはポインタか参照が必要ってだけ
571デフォルトの名無しさん
2021/04/30(金) 09:52:57.56ID:dyTEtgxA shared_ptr<T>もいけるでしょ
スタックを使った60バイト近いメモリーコピーが発生するから最適ではないけど
スタックを使った60バイト近いメモリーコピーが発生するから最適ではないけど
572デフォルトの名無しさん
2021/04/30(金) 10:40:50.56ID:7VhEvZ/Q >>569
class Animal {・・・};
class Dog : publoic Animal {・・・};
std::vector<Animal> g_list;
void func( Animal &a )
{
g_list.push_back(a);
}
int main()
{
Dog d;
func(d); // コンパイルエラーにはならないのに、スライシングが発生。駄目な例。
return 0;
}
class Animal {・・・};
class Dog : publoic Animal {・・・};
std::vector<Animal> g_list;
void func( Animal &a )
{
g_list.push_back(a);
}
int main()
{
Dog d;
func(d); // コンパイルエラーにはならないのに、スライシングが発生。駄目な例。
return 0;
}
573デフォルトの名無しさん
2021/04/30(金) 11:02:34.65ID:Qm/DlA0m >>572
スライシングが発生してるのは g_list.push_back(a) であって、 func( Animal &a ) は関係ないでしょ。
スライシングが発生してるのは g_list.push_back(a) であって、 func( Animal &a ) は関係ないでしょ。
574デフォルトの名無しさん
2021/04/30(金) 11:21:35.01ID:qs5VuYRE なんで範囲for文ってBOOST_FOREACHを完全に置き換えれるようにしなかったの?
>>537,542はそれで解決するし、逆順のループとかもできるのに
>>537,542はそれで解決するし、逆順のループとかもできるのに
575デフォルトの名無しさん
2021/04/30(金) 11:34:29.27ID:vL4rFdIy ポリモーフィズム前提の時は、コピーコンストラクタはdeleteするのが良いのかね
576デフォルトの名無しさん
2021/04/30(金) 11:43:26.05ID:qs5VuYRE577デフォルトの名無しさん
2021/04/30(金) 11:48:46.39ID:7VhEvZ/Q >>573
この場合、スライシングが発生しても問題ない、という観点もあるかも。
この場合、スライシングが発生しても問題ない、という観点もあるかも。
578デフォルトの名無しさん
2021/04/30(金) 12:01:43.38ID:W8up1rh0 >>575
そしたら派生クラス同士でコピー出来んやろ、コピー禁止にしたいのでなければ書くべき(で派生のコピーコンストラクタで基底のコピーコンストラクタを初期化リストから呼ぶ
必ず派生させて使うのが前提ならコンストラクタをprotectedにするとかその辺のテクニックは大昔から色々出てる
そしたら派生クラス同士でコピー出来んやろ、コピー禁止にしたいのでなければ書くべき(で派生のコピーコンストラクタで基底のコピーコンストラクタを初期化リストから呼ぶ
必ず派生させて使うのが前提ならコンストラクタをprotectedにするとかその辺のテクニックは大昔から色々出てる
579デフォルトの名無しさん
2021/04/30(金) 12:18:33.85ID:7VhEvZ/Q スライシングが起きるとき、基本クラス部分だけをコピーすることになるが、
その際、仮想テーブルへのポインタが継承クラス用のままだと、コピー後の
操作が危険になる可能性があるが、もし、仮想テーブルへのポインタを
基本クラス用に変えてしてしまえば、コピー後の動作は完全に基本クラス的に
なってしまうけれど、その反面、メンバー関数を呼び出しても特にメモリーの
破壊などは起きないはず。
そのようにしてしまえばスライシングが起きても問題ないような気が。
その際、仮想テーブルへのポインタが継承クラス用のままだと、コピー後の
操作が危険になる可能性があるが、もし、仮想テーブルへのポインタを
基本クラス用に変えてしてしまえば、コピー後の動作は完全に基本クラス的に
なってしまうけれど、その反面、メンバー関数を呼び出しても特にメモリーの
破壊などは起きないはず。
そのようにしてしまえばスライシングが起きても問題ないような気が。
580デフォルトの名無しさん
2021/04/30(金) 12:31:22.41ID:W8up1rh0 >>578て書いたけど実際ポリモーフィズム目的の継承ツリーだとコピー禁止にしてること多いな・・
どうせポインタ(orスマポ)で管理するから確かにコピー禁止のが無難かもね
どうせポインタ(orスマポ)で管理するから確かにコピー禁止のが無難かもね
581デフォルトの名無しさん
2021/04/30(金) 12:38:12.34ID:5yvxXz0O >>570
それぞれのコピコンをプログラマが自由に記述できる以上、例えAnimalの情報しか参照しないとしても問題が起こることはあるんじゃね?
例えば、DogのコピコンはAnimal::cuterThanCat変数を強制的にtrueに書き換えてるかもしれない
それぞれのコピコンをプログラマが自由に記述できる以上、例えAnimalの情報しか参照しないとしても問題が起こることはあるんじゃね?
例えば、DogのコピコンはAnimal::cuterThanCat変数を強制的にtrueに書き換えてるかもしれない
582デフォルトの名無しさん
2021/04/30(金) 12:51:39.69ID:W8up1rh0583デフォルトの名無しさん
2021/04/30(金) 14:49:19.98ID:qs5VuYRE 誰かBOOST_FOREACHを自作クラスに使う条件教えてください
584はちみつ餃子 ◆8X2XSCHEME
2021/04/30(金) 16:01:39.38ID:Efpw+/b3585デフォルトの名無しさん
2021/04/30(金) 20:24:33.87ID:QZYh0z4M >>579
>スライシングが起きるとき、基本クラス部分だけをコピーすることになるが、
>その際、仮想テーブルへのポインタが継承クラス用のままだと、コピー後の
>操作が危険
そんな恐ろしいことが!
と思って試したが、少なくともデフォルトのコピコンは仮想関数テーブルへのポインタを
コピー先の型に合わせて付け替えてくれるらしい
↓そうでなけれはfunc_with_ref(Animal a)の中でa2.get()がDogの値でなくAnimalの値を返す説明がつかない
https://ideone.com/eJMsYG
規格でどうなっているかは知らん
>スライシングが起きるとき、基本クラス部分だけをコピーすることになるが、
>その際、仮想テーブルへのポインタが継承クラス用のままだと、コピー後の
>操作が危険
そんな恐ろしいことが!
と思って試したが、少なくともデフォルトのコピコンは仮想関数テーブルへのポインタを
コピー先の型に合わせて付け替えてくれるらしい
↓そうでなけれはfunc_with_ref(Animal a)の中でa2.get()がDogの値でなくAnimalの値を返す説明がつかない
https://ideone.com/eJMsYG
規格でどうなっているかは知らん
586デフォルトの名無しさん
2021/04/30(金) 20:25:50.19ID:QZYh0z4M 訂正orz、
誤: そうでなけれはfunc_with_ref(Animal a)の中で
正: そうでなけれはfunc_with_copy(Animal a)の中で
誤: そうでなけれはfunc_with_ref(Animal a)の中で
正: そうでなけれはfunc_with_copy(Animal a)の中で
587デフォルトの名無しさん
2021/05/01(土) 07:00:40.64ID:2eVlBBCY ていうかよく考えたらAnimalのコピコンは
Animalのコンストラクタでもあるのだから>>585の挙動は当然かorz
Animalのコンストラクタでもあるのだから>>585の挙動は当然かorz
588デフォルトの名無しさん
2021/05/01(土) 09:21:42.94ID:C4kuj/yW コピコン
589デフォルトの名無しさん
2021/05/01(土) 09:28:33.15ID:18idEqJd コピコン
たまに見る
頭悪そう
たまに見る
頭悪そう
590デフォルトの名無しさん
2021/05/01(土) 10:19:04.33ID:tHuso9oJ でもコピーコンストラクターって長いよね
591デフォルトの名無しさん
2021/05/01(土) 10:26:47.50ID:2eVlBBCY コンストラクタはコンストラ
コピーコンストラクタはコピコン
デストラクタはデストラ
アルゴリズムはアルゴ
と略すのが効率的
コピーコンストラクタはコピコン
デストラクタはデストラ
アルゴリズムはアルゴ
と略すのが効率的
592デフォルトの名無しさん
2021/05/01(土) 10:31:05.38ID:Jen9oEOj 取引先がそんな言葉を使ってきたら
今後の契約を考え直すかも
少なくとも評価はマイナス
取引先とそんな細かい内容を話す打合せも無いだろうけど
今後の契約を考え直すかも
少なくとも評価はマイナス
取引先とそんな細かい内容を話す打合せも無いだろうけど
593デフォルトの名無しさん
2021/05/01(土) 11:21:44.35ID:fSkONWKY >>591
気持ち悪い略語だな
気持ち悪い略語だな
594デフォルトの名無しさん
2021/05/01(土) 12:04:39.12ID:zZz/KCNF デストラw
595デフォルトの名無しさん
2021/05/01(土) 12:14:30.82ID:yzll/vyD ctor,dtorは一般的な略語?
596デフォルトの名無しさん
2021/05/01(土) 12:14:41.90ID:toT74GP1 機能を引き継ぐために継承して、インスタンス化して使うために移譲もしたい
継承も移譲もするのってありですか?
継承も移譲もするのってありですか?
597デフォルトの名無しさん
2021/05/01(土) 12:45:03.96ID:toT74GP1 わかんねえ
継承が相応しくない場合が山程あるのはわかった
継承が相応しくないが一部機能を引き継ぎたいときは、コードのコピペをするべきなのか?
継承が相応しくない場合が山程あるのはわかった
継承が相応しくないが一部機能を引き継ぎたいときは、コードのコピペをするべきなのか?
598デフォルトの名無しさん
2021/05/01(土) 12:53:12.87ID:C4kuj/yW 独立させる
599デフォルトの名無しさん
2021/05/01(土) 13:13:50.17ID:toT74GP1 >>598
より小さいクラスか構造体として切り出すということ?
より小さいクラスか構造体として切り出すということ?
600デフォルトの名無しさん
2021/05/01(土) 13:18:13.99ID:T/ErWrJ0 private継承じゃダメなの?
601デフォルトの名無しさん
2021/05/01(土) 13:52:11.96ID:toT74GP1 >>600
ダメってことはもちろんなくて、そう実装することにすればそう実装するだけだが、継承である以上は依存関係が生じるし、相応しくない場合もあるなあと思うだけ
ダメってことはもちろんなくて、そう実装することにすればそう実装するだけだが、継承である以上は依存関係が生じるし、相応しくない場合もあるなあと思うだけ
602デフォルトの名無しさん
2021/05/01(土) 13:54:03.05ID:TBkH44Fh intをとるかcharを取るかで振る舞いを変えるオーバーロード関数って作れるんですか?
その場合、受け取ったのがintかcharかプログラムはどうやって見分けるのですか?
その場合、受け取ったのがintかcharかプログラムはどうやって見分けるのですか?
603デフォルトの名無しさん
2021/05/01(土) 14:19:20.97ID:I2agxka5 オーバーロードという単語を知っておきながら、何故できないと思ったんだ
604デフォルトの名無しさん
2021/05/01(土) 16:00:09.42ID:qPtffzbe >>602
関数シグネチャってもんがあるわけよ。
リンカは関数名ではなくこのシグネチャでリンクする。
引数の型が変わるとこのシグネチャが変わるので、
プログラムというかコンパイラはそれを間違えることはない。
関数シグネチャってもんがあるわけよ。
リンカは関数名ではなくこのシグネチャでリンクする。
引数の型が変わるとこのシグネチャが変わるので、
プログラムというかコンパイラはそれを間違えることはない。
605デフォルトの名無しさん
2021/05/01(土) 16:28:04.60ID:18idEqJd intとcharは使う側が間違いやすいから
間違えたら問題がある場合は名前を変えよう
間違えたら問題がある場合は名前を変えよう
606デフォルトの名無しさん
2021/05/01(土) 16:37:35.74ID:JkRHvcmQ607デフォルトの名無しさん
2021/05/01(土) 17:09:26.40ID:1WejqaZh >>602
C++で関数呼び出しを書いた場合、どの関数が呼び出されるかは
Best Matching Algorithm で選ばれているので実引数が charの場合は、
同じ場所の仮引数がcharである関数を優先的に選ぼうとする。
もし、同じ場所の仮引数がcharであるものが見つからなければ、
同じ場所の仮引数が int であるものを探して、見つかればそれを選択する。
このとき、実引数と仮引数の型の「距離」のような概念があり、
距離が近いものが選ばれる。複数の引数が有る場合で、二つの引数で
距離が近い関数がどっちもどっちになる場合には、「曖昧」であると、
され、エラーになる。
>その場合、受け取ったのがintかcharかプログラムはどうやって見分けるのですか?
ここであなたの言っている「見分ける」という意味が分かりにくいが、
オーバーロードされた関数は、C++レベルでは同じ名前に見えていてもが
アセンブラレベルでは別の関数名になっていて、別の関数として扱われていて、
別の関数が呼び出されているから「見分ける」以前問題になっている。
C++で関数呼び出しを書いた場合、どの関数が呼び出されるかは
Best Matching Algorithm で選ばれているので実引数が charの場合は、
同じ場所の仮引数がcharである関数を優先的に選ぼうとする。
もし、同じ場所の仮引数がcharであるものが見つからなければ、
同じ場所の仮引数が int であるものを探して、見つかればそれを選択する。
このとき、実引数と仮引数の型の「距離」のような概念があり、
距離が近いものが選ばれる。複数の引数が有る場合で、二つの引数で
距離が近い関数がどっちもどっちになる場合には、「曖昧」であると、
され、エラーになる。
>その場合、受け取ったのがintかcharかプログラムはどうやって見分けるのですか?
ここであなたの言っている「見分ける」という意味が分かりにくいが、
オーバーロードされた関数は、C++レベルでは同じ名前に見えていてもが
アセンブラレベルでは別の関数名になっていて、別の関数として扱われていて、
別の関数が呼び出されているから「見分ける」以前問題になっている。
>>591
コピコン以外は使わないです‥‥
コピコン以外は使わないです‥‥
609デフォルトの名無しさん
2021/05/01(土) 17:24:45.49ID:CnJDnM0a610デフォルトの名無しさん
2021/05/01(土) 17:29:02.27ID:1WejqaZh >>605
それは、実際そうだと思う。
char idx = xxx;
func( 'a' + idx );
と書いた場合、func(int)とfunc(char)のどちらが呼び出されるのかを
事前に予想するのは非常に難しい。
なぜなら、伝統的にCでは、char + char は、それぞれが int に昇格
されてから、int + int になって、結果も int になるとされていたから。
それは、実際そうだと思う。
char idx = xxx;
func( 'a' + idx );
と書いた場合、func(int)とfunc(char)のどちらが呼び出されるのかを
事前に予想するのは非常に難しい。
なぜなら、伝統的にCでは、char + char は、それぞれが int に昇格
されてから、int + int になって、結果も int になるとされていたから。
611デフォルトの名無しさん
2021/05/01(土) 18:00:18.46ID:1WejqaZh ファイル出力で、1バイト出力と4バイト出力の違いは、単に人間が見るための
stdout出力とは訳が違って、後からファイルを入力する時にその部分のバイト数の違い
が大きな意味を持つので、オーバーロードの仕組みだけでコンパイラに自動振り分け
させるのは、分かりにくいバグを入れてしまう可能性がある。
なので、やはり、出力するのは1バイトなのか4バイトなのかを、明確に関数名で
区別できるようにした方が望ましいと思われる。
stdout出力とは訳が違って、後からファイルを入力する時にその部分のバイト数の違い
が大きな意味を持つので、オーバーロードの仕組みだけでコンパイラに自動振り分け
させるのは、分かりにくいバグを入れてしまう可能性がある。
なので、やはり、出力するのは1バイトなのか4バイトなのかを、明確に関数名で
区別できるようにした方が望ましいと思われる。
612デフォルトの名無しさん
2021/05/01(土) 18:45:41.91ID:JkRHvcmQ613デフォルトの名無しさん
2021/05/01(土) 18:55:40.94ID:u3yKRN8V > 589 名前:デフォルトの名無しさん[sage] 投稿日:2021/05/01(土) 09:28:33.15 ID:18idEqJd [1/2]
> コピコン
> たまに見る
> 頭悪そう
>>595に何も言えねえ
頭悪そうw
> コピコン
> たまに見る
> 頭悪そう
>>595に何も言えねえ
頭悪そうw
614デフォルトの名無しさん
2021/05/01(土) 19:59:37.32ID:tHuso9oJ マングリング、ってなんかイヤらしいよね
615デフォルトの名無しさん
2021/05/01(土) 20:50:21.52ID:TTMGRbh+ >>612
?h@@YAXH@Z みたいなのを関数名って言うのは違和感しかないわ
> そもそもリンカはマングリングされているのかされていないのかも関知しないし。
それを言うならリンカは関数かどうかすら関知してない
?h@@YAXH@Z みたいなのを関数名って言うのは違和感しかないわ
> そもそもリンカはマングリングされているのかされていないのかも関知しないし。
それを言うならリンカは関数かどうかすら関知してない
616デフォルトの名無しさん
2021/05/01(土) 21:00:22.23ID:CnJDnM0a >>612
むちゃくちゃだなぁ。わざわざ用語をごっちゃにして何がうれしいの?
シンボルが関数を指すのか変数その他を指すのかもリンカは関知しないんじゃないの?
たとえば ld のマニュアルに function name なんて一度も出てこないし。
https://linux.die.net/man/1/ld
> ld combines a number of object and archive files, relocates their data and ties up symbol references. ...
むちゃくちゃだなぁ。わざわざ用語をごっちゃにして何がうれしいの?
シンボルが関数を指すのか変数その他を指すのかもリンカは関知しないんじゃないの?
たとえば ld のマニュアルに function name なんて一度も出てこないし。
https://linux.die.net/man/1/ld
> ld combines a number of object and archive files, relocates their data and ties up symbol references. ...
617デフォルトの名無しさん
2021/05/01(土) 21:25:44.91ID:18idEqJd 私は「関数名」派
C++のコンパイラは元々はC++からCに翻訳してたわけだし
C++のコンパイラは元々はC++からCに翻訳してたわけだし
618デフォルトの名無しさん
2021/05/01(土) 21:27:05.03ID:18idEqJd まあどっちでもいいけど
619デフォルトの名無しさん
2021/05/02(日) 00:16:29.81ID:r2Ed4Ypi620デフォルトの名無しさん
2021/05/02(日) 01:13:49.22ID:hoeVnODB オーバーライドの意味も知らない子は無理して回答しなくていいよ
621デフォルトの名無しさん
2021/05/02(日) 01:21:37.53ID:AyQRjFej C++初心者はクラス継承の学習にこだわりテンプレートの学習が後回しになるので、テンプレートが最適解になることが多いと悟るのが遅くなる
622デフォルトの名無しさん
2021/05/02(日) 01:23:19.71ID:liMkj8Q9 オーバルライトは新しいからね。
623デフォルトの名無しさん
2021/05/02(日) 01:39:37.43ID:uIjrwEP9624デフォルトの名無しさん
2021/05/02(日) 01:40:39.79ID:uIjrwEP9625デフォルトの名無しさん
2021/05/02(日) 06:37:18.08ID:pZrwNqHn626デフォルトの名無しさん
2021/05/02(日) 08:57:49.73ID:rpBXKN7W 基底クラスBで定義された int foo(double x) が派生クラスD1、D2でオーバーライドされた場合、
同じ「foo」という関数名に対して
Bのクラス名が入ったマングルされたシンボル _$F_B__foo_INT_1_DBL
D1のクラス名が入ったマングルされたシンボル _$F_D1_foo_INT_1_DBL
D2のクラス名が入ったマングルされたシンボル _$F_D2__foo_INT_1_DBL
みたいな3種類のシンボルがリンカに渡されることになり(マングリング規則は適当
、{ オーバーライドされた関数名 }と{ オーバーライドされたシンボル }の
1対1対応は崩れるのだから
関数名≠関数のシンボル
を示す例としてオーバーライドはオーバーロードと同じく妥当であることは変わりが無い
、と思うが知らん
同じ「foo」という関数名に対して
Bのクラス名が入ったマングルされたシンボル _$F_B__foo_INT_1_DBL
D1のクラス名が入ったマングルされたシンボル _$F_D1_foo_INT_1_DBL
D2のクラス名が入ったマングルされたシンボル _$F_D2__foo_INT_1_DBL
みたいな3種類のシンボルがリンカに渡されることになり(マングリング規則は適当
、{ オーバーライドされた関数名 }と{ オーバーライドされたシンボル }の
1対1対応は崩れるのだから
関数名≠関数のシンボル
を示す例としてオーバーライドはオーバーロードと同じく妥当であることは変わりが無い
、と思うが知らん
627デフォルトの名無しさん
2021/05/02(日) 09:20:39.13ID:aspEWHUD628デフォルトの名無しさん
2021/05/02(日) 10:53:26.72ID:r2Ed4Ypi629デフォルトの名無しさん
2021/05/02(日) 12:10:24.45ID:tUw9C2ed このクソ議論見ても関数オーバーロードの仕様は失敗してるってのがよくわかる。
630デフォルトの名無しさん
2021/05/02(日) 12:12:19.26ID:KNEFHTDE …などと意味不明の供述をしており、
631デフォルトの名無しさん
2021/05/02(日) 12:47:09.45ID:72ULtZJb 悪い子: この仕様はクソだ!
普通の子: この仕様は〇〇だから良くないね
良い子: この仕様は〇〇だから良くないね、△△とすれば良いのに
普通の子: この仕様は〇〇だから良くないね
良い子: この仕様は〇〇だから良くないね、△△とすれば良いのに
632デフォルトの名無しさん
2021/05/02(日) 13:06:19.55ID:hoeVnODB >>626
それは単に別のクラスで同じ名前のメンバ関数はシンボルが違うってだけの話だろ
オーバーライドは全く関係ない
そもそもオーバーライドの関数選択はvtblの仕事だからリンカは何も関知してない
オーバーロードと並べて語る意味が全くわからない
それは単に別のクラスで同じ名前のメンバ関数はシンボルが違うってだけの話だろ
オーバーライドは全く関係ない
そもそもオーバーライドの関数選択はvtblの仕事だからリンカは何も関知してない
オーバーロードと並べて語る意味が全くわからない
633デフォルトの名無しさん
2021/05/02(日) 13:16:03.71ID:B3yuABqk ダンバインよりビルバインのほうが好き
634デフォルトの名無しさん
2021/05/02(日) 13:18:20.36ID:rpBXKN7W (話に付いてこれてない香具師が居るな
635デフォルトの名無しさん
2021/05/02(日) 13:20:32.85ID:rpBXKN7W >そもそもオーバーライドの関数選択はvtblの仕事だからリンカは何も関知してない
では聞くがvtblに乗っける関数へのポインタのアドレスは誰が最終的に決めるんじゃ
ちな1つのクラスのメソッドの定義が必ずしも同一の翻訳単位内とは限らないから、
相対インデックス指定の出番は無い=コンパイル時解決は不可能
では聞くがvtblに乗っける関数へのポインタのアドレスは誰が最終的に決めるんじゃ
ちな1つのクラスのメソッドの定義が必ずしも同一の翻訳単位内とは限らないから、
相対インデックス指定の出番は無い=コンパイル時解決は不可能
636デフォルトの名無しさん
2021/05/02(日) 13:26:01.49ID:hoeVnODB >では聞くがvtblに乗っける関数へのポインタのアドレスは誰が最終的に決めるんじゃ
実行時に実行バイナリが決めるに決まってるだろ
リンカがリンク時に静的に決めるとでも思ってるの?すげえなそのリンカ
実行時に実行バイナリが決めるに決まってるだろ
リンカがリンク時に静的に決めるとでも思ってるの?すげえなそのリンカ
637デフォルトの名無しさん
2021/05/02(日) 13:27:21.13ID:anCj3LhS >>633
それはオーラロード
それはオーラロード
638デフォルトの名無しさん
2021/05/02(日) 13:46:56.51ID:KNEFHTDE よく知らんけど、多くの場合vtblを作るのはコンパイル時であって、リンク時でも実行時でもないのでは?
639デフォルトの名無しさん
2021/05/02(日) 13:50:36.00ID:h6as2k/z >>635
vtbl内のアドレスを最終的に決めるのはリンカなんだろうけど、それは
「オーバーライドの関数選択はvtblの仕事だからリンカは何も関知してない」と両立するので
反論ぽく挙げてる意味がわからない。
vtbl内のアドレスを最終的に決めるのはリンカなんだろうけど、それは
「オーバーライドの関数選択はvtblの仕事だからリンカは何も関知してない」と両立するので
反論ぽく挙げてる意味がわからない。
640デフォルトの名無しさん
2021/05/02(日) 13:51:49.77ID:AyQRjFej ビルバインはもっと禍々しいデザインになる予定だったが、競合アニメだったマクロス・シリーズの影響で変形ギミックが追加され色も派手になった
641デフォルトの名無しさん
2021/05/02(日) 13:53:08.50ID:B3yuABqk >>637
分かってくれてありがとうw
分かってくれてありがとうw
642デフォルトの名無しさん
2021/05/02(日) 13:53:56.96ID:01FRJ74M おまいら中身のある会話しろよ
ひまなの?
ひまなの?
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【地震速報】青森県で震度6強 沿岸部に津波警報 ★6 [ぐれ★]
- 「日の丸にバツ印」掲げた大学生 あいまいな国旗損壊罪に「怖い」 The Mainichi [少考さん★]
- 【音楽】BARBEE BOYS・KONTAが事故で四肢麻痺を公表、新体制で活動は継続 [少考さん★]
- 【野球】野球の未来に危機感「マイナースポーツになる」 宮本慎也氏が開催…学童大会 [尺アジ★]
- 中国「捜索レーダー起動は各国の通常の手法」 火器管制用か回答せず [蚤の市★]
- 【訃報】声優・西村知道さん死去 「SLAM DUNK」安西先生役 9月に体調不良のため一時休業 [少考さん★]
- ぺこーら、地震で同僚が次々配信を止めるなか強行し続けるので悪目立ちするwww [268244553]
- なぜ人間は架空の人物に感情移入するのか
- 【愛国者速報】山上徹也、金に困りTwitterのお金配り垢に応募していた。犯行もお金があったら暫くやらなかったと供述 [856698234]
- 年々クリスマス感が無くなってる
- 【速報】高市早苗、起床 [779938112]
- ひま
