1 名前:デフォルトの名無しさん [2021/05/19(水) 10:55:13.24 ID:LZZifCH2.net] 前スレ C++相談室 part155 https://mevius.5ch.net/test/read.cgi/tech/1616555235/
123 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 01:22:28.79 ID:3Clqo4vt.net] 初期化されてない自動変数やポインタを使うのはスリルあるね
124 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 01:28:07.59 ID:ppnc++Os.net] >>120 構文規則には、その言語(C/C++など)で定義されたパターンを、非終端記号と終端記号を 組み合わせてBNFなどを使って書く(その構文規則をコンパイラ理論では「文法」と呼んでいる。)。 トークン列が、その構文規則のパターンに当てはまる場合、「認識された」という。 このとき、認識されないトークン列はエラーであり「受理されない」。 ようは、文法規則に当てはまってないトークン列が、「受理されない/未定義」。
125 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 01:39:13.51 ID:QJfgb1eG.net] >>116 C++の宣言文において、&x を x が参照型であることを意味する文法を最初に 定義するのは、人間。そういう言語にしたいからそうしただけ。 そしてその文法は、(必須ではないが)、BNFなどを使った構文規則として仕様公開される。 C++の構文規則には、x&というパターンは書いてない。 なので、積極的に「禁止」しなくても、トークン列にx&というものが現れても、 どの構文規則にも「マッチング」しないのでエラーが表示される。 それだけのこと。
126 名前:はちみつ餃子 mailto:sage [2021/05/29(土) 02:08:34.72 ID:F7QShN9h.net] 仕様が提示する構文規則 (BNF) に合致しないというレベルの違反は診断対象規則 (diagnosable rules) に反するので処理系がユーザに通知する義務はある。
127 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 02:51:05.83 ID:gVnTXjgE.net] >>122 受理されなかった入力は非マッチなのであってエラーの一択なのでは……
128 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 02:53:15.80 ID:gVnTXjgE.net] >>123 x&とかxが型なら普通にパターンとして現れるのでは…………
129 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 03:11:30.39 ID:gVnTXjgE.net] 「C++の構文規則にマッチする入力テキストの集合」が一意確定になることを疑う理由は無いから 入力テキストにわざわざ未定義などというクラスを設けるする必要は無いのでは……………………
130 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 03:13:13.35 ID:QJfgb1eG.net] >>126 構文規則の中に x&y は存在しているが、x&単独では存在していない。 だから、z = x&y; や z=(x&y) は受理されるが、z = x&; や z=(x&) はエラーになる。
131 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 03:14:43.85 ID:QJfgb1eG.net] >>126 おっと、読み間違えた。 xが型の場合は受理されるよ。 xが名前トークンの場合は受理されない。
132 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 03:21:31.22 ID:QJfgb1eG.net] >>129 [補足] ・xが名前トークンでも意味論的にxが型名とみなせる場合にはxは型だと扱われる。 ・xが変数名の場合には変数だとみなされる。 ・xが変数名の場合には、x&yは文法の中の有る規則にマッチングするので 受理されるが、xが変数名の場合にはx&という文法規則は存在してないので どんな文法規則にもマッチングできないのでエラーになる。
133 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 03:24:12.95 ID:QJfgb1eG.net] >>130 [さらに補足] ・xが(ユーザー定義の)型名の場合でも、それが現れる文脈次第で x&が受理され無い事がある。 文脈によって受理されるパターンが違うので。
134 名前:デフォルトの名無しさん [2021/05/29(土) 16:51:48.20 ID:thkl3N6c.net] たぶんくそしょうもない質問いいですか コンストラクタの初期化子リストで まさに今初期化したばっかりの他のメンバを使うのはアリですか class Foo{ Foo(Bar bar,Baz baz); Bar bar_; Baz baz_; ... }; Foo::Foo(Bar bar,Baz baz) :bar_(42) ,baz_(bar_) // ← これ {... 自分の環境では動いてるようですが 規格に照らし合わせて合法なものなのでしょうか?
135 名前:デフォルトの名無しさん mailto:sage [2021/05/29(土) 16:59:07.85 ID:RxiQSMqK.net] >>132 クラスのメンバ変数は定義に書かれた順に初期化されるから、その例についてはokなんじゃないかな
136 名前:はちみつ餃子 mailto:sage [2021/05/29(土) 17:29:48.88 ID:F7QShN9h.net] メンバ初期化子として書いた順ではなくクラス定義内のデータメンバ宣言順に従うというのが重要ポイントで、 勘違いを防ぐために宣言順とメンバ初期化子の順序は一致させるのが一般的な習慣になってる。 (一致させなくてもそれ自体は規格違反ではない。) C++20 から入る指示付初期化 (Designated initialization) で順序を一致させるのが必須に なっているのはこのへんの反省があったんだと思う。
137 名前:デフォルトの名無しさん [2021/05/29(土) 19:10:01.56 ID:thkl3N6c.net] 各位 ありがとう >>134 後半はへーって感じなので調べてみる
138 名前:デフォルトの名無しさん mailto:sage [2021/05/31(月) 20:14:45.42 ID:OyXVhXUR.net] 構造化束縛とか範囲for文が必ず新規にオブジェクトを宣言しないといけない仕様になってるのが何気に解せないのだが 既存のオブジェクトを使い回せた方が都合良いだろうに、なぜこういうことになったの?
139 名前:デフォルトの名無しさん mailto:sage [2021/05/31(月) 20:47:21.20 ID:6/QCGWOG.net] 構造化束縛の方はtieで行けるだろ int a, b; std::tie(a, b) = std::make_pair(1, 2);
140 名前:デフォルトの名無しさん mailto:sage [2021/05/31(月) 20:48:51.74 ID:7Qq6EdKQ.net] 参照じゃダメ?
141 名前:デフォルトの名無しさん mailto:sage [2021/05/31(月) 21:28:28.96 ID:s2XLu44M.net] c++11やり始めた頃、for(auto& e:〜やfor(const auto& e:〜と出来るのを知らず、酷いコードを大量に垂れ流してしまったよ
142 名前:デフォルトの名無しさん mailto:sage [2021/05/31(月) 22:31:51.93 ID:OyXVhXUR.net] >>138 参照にしてもfor文のスコープ外で宣言できた方が都合が良いことがままある
143 名前:デフォルトの名無しさん mailto:sage [2021/06/01(火) 01:12:38.27 ID:reo3/Kbw.net] ループの最後の値を使いたいという事?
144 名前:デフォルトの名無しさん mailto:sage [2021/06/01(火) 09:11:18.08 ID:qu3686ge.net] >>140 言っても「稀に」程度だろうし、やりたければスコープ外で宣言した変数に代入すれば済む。 何を問題としているのかわからない。
145 名前:デフォルトの名無しさん [2021/06/01(火) 12:18:45.46 ID:GfvVYbqX.net] お漏らし推奨
146 名前:デフォルトの名無しさん mailto:sage [2021/06/01(火) 12:20:20.23 ID:cpTyMADV.net] 自作関数の引数を initializer_list にするのってなんか使い道あるんですか? 参照の組を渡せる?
147 名前:デフォルトの名無しさん mailto:sage [2021/06/01(火) 18:21:02.43 ID:S9WvGpu9.net] MyVector v{1,2,3,4,5}; とかできる
148 名前:デフォルトの名無しさん mailto:sage [2021/06/01(火) 20:14:13.74 ID:Y6fKUmaQ.net] ま、まいべくたーw
149 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 06:27:13.91 ID:P6q02jmG.net] >>145 コンストラクタの引数にするくらいしかメリットないの? 前スレ掘ってたら、同じ型の参照の組なら initializer_list で関数に投げれるってのを見つけたんだ
150 名前:ェそれはどうやんの initializer_listを引数にとる関数 hoge を hoge({fuga, var, aaa}) って呼び出したら実体を渡してることになるよね? [] [ここ壊れてます]
151 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 06:48:10.69 ID:2dvb28jp.net] MyVector(initializer_list<reference_wrapper<int>>) { }
152 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 07:01:45.97 ID:P6q02jmG.net] >>148 それって vector< reference_wrapper<T> > とは違うんけ?
153 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 07:55:44.63 ID:2dvb28jp.net] template <class T>をつけるならね
154 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 07:57:13.92 ID:2dvb28jp.net] reference_wrapperはC++11からでC++03にはないから> >にする意味ないぞ
155 名前:デフォルトの名無しさん [2021/06/02(水) 08:15:03.57 ID:c6cNO3VA.net] 初期化のときに登場する{}が初期化子リストだと言うことがつい最近判明した 概念を区分して分離したのが一番大きいので、用途についてはあまり考えられていない
156 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 08:44:42.49 ID:P6q02jmG.net] >>151 いや自分の可読性のためにそうしてるだけ 他の人にとってはそっちの方が見づらかったらすみません それはそうと、関数に参照の組を渡すなら、initializer_list 云々というよりは reference_wrapper の組として渡すってことですね もう一点、関数に initializer_list を渡すときって ・関数の引数の型が initializer_list である よりも ・関数の引数のコンテナを initializer_list で初期化している の方がしっくりくるんですが、前者で設計するメリットってありますか
157 名前:デフォルトの名無しさん [2021/06/02(水) 10:14:59.83 ID:qtmfAhQ7.net] overloadに弱くなる
158 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 10:21:56.66 ID:2dvb28jp.net] >>153 長かったC++03時代でそういうクセが染みついちまった、ならわかる
159 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 10:48:08.32 ID:zppGp/iM.net] 気狂いいてワロ (a, b, c) と ( a, b, c ) さえどちらが良いかなんて誰にも決められないのに、なぜ < <> > と <<>> なら後者の方が問答無用で良いと思い込んでるのだろうか こういう、一概には言えないことを押し付けるタチの異常者が回答側に回ってるのイタ過ぎだろ
160 名前:デフォルトの名無しさん [2021/06/02(水) 10:51:36.57 ID:qtmfAhQ7.net] 同和ンゴ
161 名前:はちみつ餃子 mailto:sage [2021/06/02(水) 11:11:42.37 ID:Bcy6nIKX.net] トークン分割の段階では >> というひとつのトークンとして切り出された上で 構文解析の側で辻褄を合わせるという変な解釈が不格好だから好きじゃないな。 構文が複雑になる分には仕方がないと割り切れるんだが、 異なるレイヤをまたいで辻褄合わせするのってなんか嫌じゃない? でもまあ > > よりは >> のほうが見やすい気がするからそう書いてるんだけど、 割とモヤモヤしがち。
162 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 11:13:17.27 ID:2dvb28jp.net] 何で押しつけたことになるんだ? 被害妄想で攻撃的になるやつこそ病んでるぞ スタイルは案件ごとにある そこでいらぬ波風立てるやつは叩き出される 仕事は成果で語るものなのに勘違いして つまらんことに気を取られるやつは使い物にならん
163 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 11:41:07.35 ID:vfPidZYU.net] >>149 おそらく初期化子リスト版の方が高速に動作する まぁ、今時のコンパイラの最適化は変態レベルに進化してるから結局同じようなコードに落ち着くかもしれないけど
164 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 11:54:53.84 ID:P6q02jmG.net] >>154 initializer_list をとることにしておけばコンテナの種類を決めておく必要がないから得ってことですか?
165 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 12:01:59.24 ID:zppGp/iM.net] >>159 > スタイルは案件ごとにある 元質問はスタイルが指定された案件では全くないので、自分が頓珍漢なこと言ってたって認めるわけね > そこでいらぬ波風立てるやつは叩き出される > つまらんことに気を取られるやつは使い物にならん 狂おしいまでに己のことだな
166 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 12:11:17.92 ID:2dvb28jp.net] >>162 元質問には特定の案件か否かはどちらとも書いていないね さらに俺は特定の案件の話だともそうでないとも言ってない 次から次へと勝手に決めつける軽率なやつが 他人に向かって頓珍漢とか天に唾するってやつだぜ
167 名前:デフォルトの名無しさん mailto:sage [2021/06/02(水) 12:24:56.03 ID:e/VYBb4b.net] 恥ずかしくなってネタっぽくしてるが隠しきれてない同和ンゴ
168 名前:デフォルトの名無しさん mailto:sage [2021/06/04(金) 15:31:20.39 ID:Lunsq3fv.net] cout と cerr に同じもん流し込みたいときって cout << hoge; cerr << hoge; ってやるしかない? 一行というか一文で書けたら楽だが
169 名前:デフォルトの名無しさん mailto:sage [2021/06/04(金) 15:57:51.35 ID:xvizFE5L.net] >>165 すなおに以下のようなマクロにしとけばどうかな #define HOGE(x) std::cout << x; std::cerr << x; 例えば以下のように使う HOGE(hoge << endl);
170 名前:デフォルトの名無しさん mailto:sage [2021/06/04(金) 17:29:57.12 ID:7u0nl5aT.net] random_device{}(); の中括弧って何なん デフォルトコンストラクタで構築するってこと? なんで丸括弧じゃないん
171 名前:デフォルトの名無しさん mailto:sage [2021/06/04(金) 18:26:04.60 ID:XeNJRf+j.net] 別に中()でも問題なくない?
172 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 05:37:22.25 ID:Fi/fLauk.net] ラムダ式のキャプチャ構文の個別コピーとか個別参照がなんで存在するのかイミフなんだが 引数で良いじゃん
173 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 07:13:07.04 ID:RvyziTet.net] キャプチャにもコストは掛かるから必要なものだけ最小限キャプチャしたい時に必要なんだよ なぜ引数でいいと思うのかはイミフ
174 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 07:24:52.28 ID:qiBnX5wX.net] 既存の関数ポインタや関数オブジェクトと整合性を取るには、寿命やスコープの異なる変数を使うための仕組み(キャプチャ)が必要だったからでしょ
175 名前:デフォルトの名無しさん [2021/06/05(土) 07:29:08.22 ID:qiBnX5wX.net] とあるラムダ式を読みづらいと感じるならそこでは使わないほうがいい 煽っているわけではなくて、ラムダ式の存在意義は可読性の改善なので、ラムダ式を読みづらいのは本末転倒だからね
176 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 07:39:00.13 ID:ywjQFJII.net] >>170 キャプチャデフォルトにしても使わなかったやつはキャプチャされないから あえて個別にするのは何か理由があるときだね
177 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 08:28:34.32 ID:NuQvqfvD.net] >>170 キャプチャできるオブジェクトってみんな引数としても渡せるじゃん 参照、const参照、コピーも自由自在だし コストって言うけど、参照キャプチャと参照渡し、コピーキャプチャとコピー渡しってコスト違うの? 一応断っておくと[&]と[=]の存在意義は分かる オブジェクトを個別にキャプチャするのがイミフってだけ 「こういうときに使う。引数渡しではできない」という例があったら教えていただきたいです
178 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 08:43:36.40 ID:hPuZ+cGi.net] ラムダ式がキャプチャするタイミングと呼び出すタイミングは違ってもいい
179 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 08:53:12.54 ID:qiBnX5wX.net] 呼び出し時にキャプチャ元の存在は保証されない自己責任
180 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 09:10:01.93 ID:ywjQFJII.net] >>174 これを引数渡しではどう書く? random_device dev; int ary[256]; generate(begin(ary), end(ary), [&]{ return dev(); });
181 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 09:10:44.09 ID:S25kPsaU.net] >>175 なるほど コピーしたいけど呼び出しの度には嫌だ、というときに役立つのか 神機能だな
182 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 09:11:42.81 ID:S25kPsaU.net] >>177 もう解決しました
183 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 09:21:58.27 ID:tBDt+1bH.net] >>176 コピーならHOSYOUされる >>178 つか新しい関数を作る機能 >>169 カリー化
184 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 09:28:59.14 ID:tBDt+1bH.net] 普通のキャプチャ(コピー)ではなくて 異常なキャプチャ(参照のキャプチャ)なら呼び出し時にキャプチャ元(参照されているオブジェクト) の存在はHOSYOUされないから注意しないとKIKENだが なんでそんな機能があるのかというとオブジェクトをカリー化(?)する場合にあったら便利だねえ、ぐらいの勢いの話 普通のキャプチャだけでもポインタをキャプチャしたら同じことができる
185 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 09:37:27.71 ID:tBDt+1bH.net] もっとも、自動変数として作られたオブジェクトxをキャプチャする場合、 xを参照のキャプチャする代わりに&xを普通のキャプチャしてしまうと (「&」演算子が使われたことにより)微 妙に最適化に響きかねない問題というのは微妙にあるが微妙なので普通は気にするほどではないはず……
186 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 09:53:54.69 ID:qiBnX5wX.net] 元のデータをFUCKYUできないような書き方はAUTO
187 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 10:05:44.68 ID:ywjQFJII.net] キモい言葉遣いヤメレ
188 名前: mailto:sage [2021/06/05(土) 15:25:47.75 ID:CJl2tIqC.net] ヒドロキシクルルキン イベルメクチン
189 名前: mailto:sage [2021/06/05(土) 15:26:27.50 ID:CJl2tIqC.net] ヒドロキシクロロキン イベルメクチン
190 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 16:15:28.53 ID:ftrSVS/I.net] C++において関数は第一級オブジェクト なのに C++ が関数型プログラミングを全く想定していない仕様に思えるのはなぜ
191 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 16:15:54.58 ID:ftrSVS/I.net] 関数型のパラダイムもうまく取り込んでほしい
192 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 16:34:45.82 ID:Cv4CPRao.net] >>187 古いから。 >>188 提案するのは自由だから、がんばって。
193 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 16:53:27.35 ID:KLv4XYoF.net] >>187 c++の関数は第一級オブジェクトじゃないだろ。 高階プログラムはテンプレートという別の仕組みでサポートしている。
194 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 18:54:44.68 ID:V38nFCWr.net] 関数型プログラミングは別に古くないはず…… GENJITSU世界が状態を持ち破壊的代入を伴うから まだチューリングマシン的な計算モデルの方が対応がとりやすい(気がする)だけ C/C++が関数型プログラミング一本鎗にならないのはそれが根本原因
195 名前:デフォルトの名無しさん [2021/06/05(土) 20:10:51.62 ID:rl6U/q41.net] ・弱体化された関数型の機能 ・構造化プログラミング ・GOTO文 これがCだよ で、多分70年代当時は関数型プログラミングはおそらく過去の遺物になってた でないとこの頃のlispの失速が説明つかない
196 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 20:22:19.29 ID:RvyziTet.net] 当時生まれてないけど あのマシン性能が貧相な時代によくLISPなんて流行ってたな
197 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 20:31:42.60 ID:lZ3sFmcT.net] むしろマシンリソースが少ない時代だからこそ流行したといえる LISPマシンはすなわちスタックマシンだ 複雑な語句パーサーとツリー構造の構築がなくても、ストリームから はいってきたキーワードを順繰りに解釈してスタックにつんでいき かっこが閉じたらスタックからひっぱればちゃんと動くものがつくれる
198 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 20:53:06.54 ID:ywjQFJII.net] >>190 禿は「第一級オブジェクト」をテンポラリでないオブジェクトと言っているようだが
199 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 21:21:58.41 ID:XO/wZGzq.net] 権威者がこれこれと言ってたからこれこれであるという話の持って行き方は 今日の世界では小学生レベルの人間しかしない 中世ヨーロッパでは過去の偉人の言葉をいかにうまく引くかが議論の上手下手を左右したらしいが
200 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 21:28:06.29 ID:ywjQFJII.net] その世界の教祖のような人でも一切、言葉を引いてはいけないのか 小学生で年収1000越えそうな人ってジュジュちゃんとかいるけど 自分の年収を棚に上げてわかったようなことをw
201 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 22:00:37.95 ID:ECg4taz5.net] >>194 それForthじゃね?
202 名前:はちみつ餃子 mailto:sage [2021/06/05(土) 22:00:51.75 ID:G0EcoOQC.net] >>196 ここで必要なのは範例ではなく定義。 何が正しいのかを議論したいわけじゃなくてどの定義を使う「ことにする」という擦り合わせ。 C++ における定義を決めるなら設計者の言を元にするのは妥当だろ。 それはそれとして >>195 はなんかおかしいこと言っていると思うし、 なんか勘違いしてそうな気がするが。
203 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 22:49:20.33 ID:V38nFCWr.net] 関数型プログラミングが古いと主張する香具師は MVCとかなMと表示等が分離した設計モデルでありかつ Mがマルチスレッド(UIスレッドとは別)なケースのプログラミングを ラムダ式を使わずにして見られれば宜しい すっきり収拾をつけるにはコールバック関数として関数オブジェクトを渡すか、 コールバック関数をvoid*引数の関数にするという前近代的な設計にするかしかなく、 classを使って手で書く関数オブジェクトはラムダ式を見たコンパイラが生成するコードと大差ないから 前者は関数型プログラミングに他ならない という印象、 ※ 個人の感想です それはそれとして>>192 も相当おかしいことを言っていると思うし以下略
204 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 23:04:19.70 ID:V38nFCWr.net] Promiseを使っても同じことで、 ていうかPromiseこそあるスレッドXを実行後に行うべき処理を行う関数Fを スレッドXの終了後に実行するために(※1)内部で作っておくのだから関数型プログラミングに他ならない 関数型プログラミングパラダイムは全世界をあまねくみそなわしておられる、 ※1: 実行する、というといかにも命令型プログラミングな感じだが、 関数型プログラミングパラダイム的には関数Fを展開することで計算を遂行する、と解釈されたい
205 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 23:25:00.00 ID:XO/wZGzq.net] >>197 年収が人間の価値だと思う人って今でもいるんだね
206 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 23:41:37.67 ID:L7L31nHe.net] 関数型の実戦で使えるエッセンスは10年前から各種人気の言語で取り込まれ、 具にも付かない思想倒れな部分は取り込まれなかった。それだけ。
207 名前:デフォルトの名無しさん mailto:sage [2021/06/05(土) 23:54:03.24 ID:YIeCSJoh.net] >>196 上下を左右するとな。 今日一番心に残った表現だ。
208 名前:はちみつ餃子 mailto:sage [2021/06/06(日) 02:06:47.21 ID:KdK5uVMj.net] Scheme だとプログラムの流れ (関数を呼出したり戻ってきたり) を継続の起動の連鎖として 定義づけているが、継続の概念の元になったのは並列計算の研究から生まれたアクター。 アクターにメッセージを送るのと関数呼出しが実装上は同じになってしまったという気づきから継続の概念へと整理されていった。 関数型とオブジェクト指向は整理の仕方が違うだけで (といっても人間が使う以上はどのようなメタファで整理されているかも大事でもあるんだけど) より抽象的なレベルで見ると同じことをやっている。 そんで並列計算は (理論上は) どっちでも織り込み済みなのでパラダイムによって どちらのほうが並列計算しやすいということもない。 差があるとしたら単に言語の設計の出来栄えとかライブラリの整備とかのレベルの話なんで、 パラダイムにまで踏み込んで考えるような話じゃないよ。
209 名前:デフォルトの名無しさん mailto:sage [2021/06/06(日) 07:44:49.65 ID:uVO5juz1.net] 高所得者「年収が人間の価値だと思う人って今でもいるんだね」 低所得者「年収が人間の価値だと思う人って今でもいるんだね」
210 名前:デフォルトの名無しさん mailto:sage [2021/06/06(日) 08:33:32.64 ID:MV541K/D.net] >>203 C++に取り込まれた、実践で使える関数型のエッセンスってどんなん
211 名前:デフォルトの名無しさん mailto:sage [2021/06/06(日) 08:36:03.93 ID:xXlGkHu+.net] bind
212 名前:デフォルトの名無しさん mailto:sage [2021/06/06(日) 10:44:07.49 ID:+heRuwS3.net] 深さが任意の入れ子の vector を一次元 vector に展開したいんですが、良いやり方ありますか 再帰すれば良いと思うんですがどういう条件で分岐すれば良いかわかりません
213 名前:デフォルトの名無しさん mailto:sage [2021/06/06(日) 11:34:06.74 ID:5eq/ZHJS.net] 入れ子を一階層だけ展開する処理を書いて 入れ子がなくなるまで末尾再起するというのはどうだろうか
214 名前:デフォルトの名無しさん mailto:sage [2021/06/06(日) 11:37:51.02 ID:+heRuwS3.net] >>210 今見てる階層の一個下がvectorか値かっていうのはどう判定したら良いですかね?
215 名前:デフォルトの名無しさん [2021/06/06(日) 11:56:07.70 ID:W7O34OA1.net] >>209 これ flatten - 1.57.0 https://www.boost.org/doc/libs/1_57_0/libs/fusion/doc/html/fusion/algorithm/transformation/functions/flatten.html
216 名前:デフォルトの名無しさん [2021/06/06(日) 12:00:46.49 ID:W7O34OA1.net] 大抵の言語でその手の挙動はflattenと呼ばれてる Yet Another Common Lisp Problems www.nct9.ne.jp/m_hiroi/clisp/yaclp03.html#ans51
217 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 08:16:50.61 ID:we1Omxer.net] >>197 肝心なのは「誰が言ったか」ではなくて、「(言った)意味、中身」。 さもないと「権威に訴える論証」にひっかかるから気をつけな。 わかってやっているなら詐欺師だし。
218 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 09:33:53.85 ID:3qfiWg/V.net] >>210 ちょっとググった感じだと、vector<T> が vector かどうか判定する is_vector ってないんですね あと is_array は std::array を array と見なさないみたいな情報もあって、メタ関数は罠というか勘違いが多そうで怖いですね 現状、自分で is_vector を実装するしかないんですかね? ごく基本的な処理に思えるので、シンプルな解法というかイディオムみたいのがあれば教えていただきたいです >>212 ありがとうございます。が、今は自分で書くならどうなるかというところに興味があります boost の flatten のコードはいろんな場合に対応するべく難解になっていそうですが、どうにもならなかったら参照してみます
219 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 09:55:32.64 ID:BbDyCKOj.net] >>215 正直、まず>209の「深さが任意の入れ子の vector」をどう定義してるのか見せてもらわないと話が見えてこない気がする。 要素型が固定なら要素型のほうで判定すれば is_vector は要らないだろうし、 variant とか使ってる場合もやっぱり is_vector の出番は無いだろうし。
220 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 10:34:55.50 ID:RKkN9u5/.net] >>216 vector< vector< ... vector<T> > ... > で、T は correction (vector, array 等) じゃない、というのを想定しています 仮定が足りませんでしょうか
221 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 10:44:19.30 ID:OrLbPX6K.net] >>214 偉そうにキリるなら「第一級オブジェクト」の公式な定義をまず出せ
222 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 10:49:36.03 ID:OrLbPX6K.net] >>215 作るったって大した話じゃねえべ template <template<class...> class T> struct is_vector : false_type { }; template <> struct is_vector<vector> : true_type { }; template <template<class...> class T> constexpr bool is_vector_v = is_vector<T>::value;
223 名前:デフォルトの名無しさん [2021/06/07(月) 10:54:39.46 ID:BLDePS2Q.net] >>217 numpy の reshape / flatten / ravel みたいなの想定してる?
224 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 11:00:59.34 ID:BbDyCKOj.net] >>217 それじゃ深さ固定じゃね?・・・深さの違ういくつかのケースを扱うっていうことか。 T を受け取るオーバーロードとそれ以外を受け取るオーバーロード書けばおしまいな気がする。
225 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 11:02:02.86 ID:BbDyCKOj.net] (要素ごとに深さが異なることもあるのを想定してた。)
226 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 11:12:04.97 ID:3qfiWg/V.net] >>219 ありがとうございます よく知らない構文も混ざってるので、勉強します >>220 はい flatten をしたいです >>221 template<class T> T flatten(vector<T>) と template<class T> T flatten(T) ってことじゃないですよね? >>222 >>217 ってそれ含みませんっけ?
227 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 11:14:17.08 ID:3qfiWg/V.net] そもそも厳密な書き方じゃないので、含むか含まないかわかりませんね 今は含まないということにします
228 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 11:59:15.70 ID:0mm9pDbq.net] >>218 そもそもc++には「第一級オブジェクト」なんて定義されてないだろ。 c++標準に"first-class object" なんて記載あったかね。 一般的な解釈はwikipediaでも勉強しろよ。
229 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:01:22.38 ID:OrLbPX6K.net] >>225 ここはC++スレだ 一般的な解釈なんて頓珍漢なこと言ってんな そっちへ逃げたければ1人で逃げろ 俺は付き合ってやんね
230 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:05:00.74 ID:0mm9pDbq.net] >>226 だったら「第一級オブジェクト」なんて頓珍漢なこと言ってんな そっちへ逃げたければ1人で逃げろ 俺は付き合ってやんね
231 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:08:12.54 ID:OrLbPX6K.net] >>227 流れくらい読めよ 第一級オブジェクトと言ったのは>>187 だぞ おまえ他人に頓珍漢なんて言う資格ねえぞ
232 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:28:32.41 ID:5RAm1+EE.net] 一昨日の曖昧イキリで今さらヒートアップしてんじゃねー
233 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:36:56.22 ID:0/HU77Xe.net] >187、>190 、>195 、>197、>214 の流れくらい読めよ 禿の権威にかこつけて「第一級オブジェクト」を主張しているのは>>195 >>197 だぞ。俺はそれに>>214 で反論しているだけで「第一級オブジェクト」は肯定していない。 おまえ他人に頓珍漢なんて言う資格ねえぞ
234 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:44:36.71 ID:OrLbPX6K.net] >>230 おまえの定義では斜め上な返事のことを反論というのか 関数は第一級オブジェクトか否かで揉めてるところへ 禿の定義を参考に持ち出したところへ 権威主義がどうたらと人格批判を始めたのが反論とは笑止千万 だから頓珍漢と言ってやったら相手の言葉をオウム返しし初めやがって いくら寂しいからってプログラム技術板で全然技術的でない絡み方してんなよ
235 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:48:56.88 ID:x1bKzWtQ.net] 流れ一切読んでないけどFirst-class citizenのことを言いたかったのかなw
236 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:49:49.89 ID:RKkN9u5/.net] こいつ「天に唾する」クンでしょ >>219 もコピペでドヤってるし
237 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:51:26.64 ID:OrLbPX6K.net] >>233 失礼な奴だな オリジナルだよ コピペじゃねえよ 他で同じもん作ったやつがいたの? 知るかそんなん
238 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 12:52:10.37 ID:0/HU77Xe.net] >>231 日本語でok
239 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 13:04:49.21 ID:OrLbPX6K.net] >>235 無教養なやつだな、まあいいけど 犬を相手に話したことが通じてなくても別に構わんのと同じだ
240 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 14:29:25.71 ID:OrLbPX6K.net] あの程度のコードをコピペだと思ってしまうあたり 自分では書けないやつなんだろうな だとしたらプログラム技術板では最下層のゴミだ
241 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 14:43:17.86 ID:Tp4rg2N9.net] 効きまくりでクソワロ
242 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 14:45:04.77 ID:8yb86Hta.net] 5hは初めてか?肩の力抜けよ。 「第一級オブジェクト」についてはこんな感じだな。間違っていたら解説してくれ。 ・c++では「第一級オブジェクト」は定義されていない ・c++では関数はオブジェクトじゃないし、オブジェクトとして扱うこともできないので、c++の関数をwikipediaにあるような解釈で「第一級オブジェクト」と言うことはできない ・関数を操作対象として(メタ)プログラムする仕組み(テンプレートとか関数オブジェクト・ラムダ式)があるので、高階プログラム自体は可能
243 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 14:57:20.33 ID:3ylBisjG.net] 第一級オブジェクト、よくイキりのWEBプログラム屋が使う印象の単語 C++界隈ではあんまり聞かん単語だな、使わないことはないが
244 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 15:02:43.23 ID:JV8K97H/.net] std::functionで「第一級オブジェクト」とやらに出来ることは何でも出来るからそれで充分であって そっから先はただの宗教戦争だろ
245 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 15:10:41.88 ID:pl6618+T.net] 第一級市民オブジェクト フランス革命で殺されたかも?
246 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 15:32:32.79 ID:Tp4rg2N9.net] >>241 > std::functionで「第一級オブジェクト」とやらに出来ることは何でも出来る 俺も完全にこれの話だと思ってた
247 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 15:35:57.19 ID:Tp4rg2N9.net] ただ純粋関数型言語のようには書きたくても書けないよね、というのが>>187-188 の話だと
248 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 15:38:30.60 ID:OrLbPX6K.net] >>238 は? 尻尾巻いて逃げた負け犬の分際で何か言ったか?
249 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 15:41:28.23 ID:Tp4rg2N9.net] つーか > 「天に唾する」クン なのは図星なのかよって思うとまたワロタ
250 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 16:02:18.11 ID:OrLbPX6K.net] >>246 そんなとこ見てねえよ コピペ呼ばわりから逃げたいのか? 吐いた唾は飲ませんぞ、自分で書けない低脳が
251 名前:デフォルトの名無しさん mailto:sage [2021/06/07(月) 16:40:25.13 ID:8yb86Hta.net] >>241 まあ、c++は歴史が長いから、他人には禁止したい余計な機能はあるよなぁ。 以前、ユーザー側からどうやってもdeleteできないスマートポインタを作ろうとしたけど、どうしても::deleteをブロックできなくて挫折した。……まあ、::delete使うやつはいないだろうけど。 あと、オブジェクトのライフサイクル制限を目的としてヒープに置けない(スタックだけに置ける)クラスを作ろうとしたけど、メンバ変数に置くのをブロックできなくて挫折した。
252 名前:デフォルトの名無しさん mailto:sage [2021/06/08(火) 10:43:30.63 ID:x/Of6Ttl.net] そういうしょうもない機能作ることに時間をかけるくらいならバカを雇わない方がよっぽど生産的だわ
253 名前:デフォルトの名無しさん mailto:sage [2021/06/08(火) 11:14:53.81 ID:50eCybWC.net] しょうもないかねえ 俺は技術的に色んなことを想像したぞ
254 名前:デフォルトの名無しさん mailto:sage [2021/06/08(火) 11:37:14.14 ID:x/Of6Ttl.net] しょうもないわ。 注目するのはなぜdeleteしようとしてんの?ってとこでしょ。 それを無理に禁止してもそいつはもっとめちゃくちゃなことするぞ。
255 名前:デフォルトの名無しさん mailto:sage [2021/06/08(火) 11:46:10.34 ID:50eCybWC.net] しょうもないことにしたいやつは考えること自体を拒否するから 相手すんの馬鹿らしいわ
256 名前:デフォルトの名無しさん mailto:sage [2021/06/08(火) 14:05:51.36 ID:8EXn3XTK.net] 自分も昔似たようなこと考えたことはあったけど operator->()を実装する限り、直接呼び出しでナマポ取られちゃうのを防ぐ方法がないんだよな しょうもないことは否定しない
257 名前:デフォルトの名無しさん mailto:sage [2021/06/08(火) 14:21:31.17 ID:xX
] [ここ壊れてます]
258 名前:U8pzBk.net mailto: すぐには実用的な用途は思いつかないからしょうもないかどうかは判断できないけどパズルみたいなもんで趣味としてやるならいいんじゃね? [] [ここ壊れてます]
259 名前:デフォルトの名無しさん mailto:sage [2021/06/08(火) 14:23:46.24 ID:eGG/8TZ/.net] 自分で使う分には全然問題ないんだけどな。他人が絡むとマーフィーの法則が恐ろしい。 パラノイアなのは否定しない。
260 名前:デフォルトの名無しさん mailto:sage [2021/06/08(火) 14:55:17.86 ID:RogQNf7Q.net] 旅行バッグに荷物をきっちりと
261 名前:lめてから荷物の入れ忘れに気づく徒労感を楽しみたい人だけやればいい [] [ここ壊れてます]
262 名前:デフォルトの名無しさん mailto:sage [2021/06/08(火) 15:32:28.52 ID:50eCybWC.net] ピンプってる場合だってクラックはやればできる そういうのまで完璧にガードするのか否かで考え方変わってくるからな
263 名前:デフォルトの名無しさん mailto:sage [2021/06/09(水) 07:49:45.61 ID:ZYaksnCf.net] 標準にだって「禁止」や「非推奨」はあるね
264 名前:デフォルトの名無しさん mailto:sage [2021/06/09(水) 18:54:04.56 ID:N9xjQvrw.net] autoでなにか受けるときに、参照を使う方がユニバーサル参照を使うより良い場合ってある?
265 名前:デフォルトの名無しさん mailto:sage [2021/06/09(水) 21:30:11.98 ID:QYfnOwKH.net] const参照であればいい場合もあると思う。
266 名前:デフォルトの名無しさん mailto:sage [2021/06/09(水) 22:33:15.24 ID:9teK4oYw.net] >>260 ホワァイ?
267 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 06:52:19.94 ID:Wg8t0Pwp.net] 規格票を検索してもuniversal referenceというフレーズはヒットしない
268 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 07:54:30.31 ID:795Q5O5L.net] もともと名前がなかったので、通称としてuniversal referenceとかforward referenceとか呼ばれるようになったんよ
269 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 10:15:03.53 ID:p1gVn+om.net] >>262 forwarding reference でどうぞ。
270 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 14:55:46.69 ID:QNK25992.net] std::vector<A>を、std::vector<B>を使ってソートしたい場合 どうするのがスマートでしょうか? 例えばAが生徒の名前、Bがその生徒の得点だとして・・・ struct C{A a; B b;}を定義してvector<C>を作ってそれの比較演算子を作って・・・というのは思いつきますが もっといいやり方ってありますかね?
271 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 15:02:18.84 ID:Wg8t0Pwp.net] 名前、得点の他に何か、たとえば出席番号や出席日数などがあるなら 名前と得点だけのstruct C { A a; B b; }; を作るのは得策じゃなさそうだな 全てのデータが載ったマスターデータを作っておいて、 そのレコードへのポインタでvectorなり何なり作ってソートしては?
272 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 17:03:39.84 ID:PlM5zQeB.net] vector<C>みたいなものを作りたくないならAとBのvectorの要素間の対応関係はどうやって守るつもりなの? 片方だけソートしたら壊れちゃうぞ 元データは触らずにindexのvectorを別に用意して、[](int x, int y){return b[a] < b[y];} でソートする手もあるけど
273 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 17:04:25.52 ID:RDo2P64U.net] >>260 割となんでか気になるので、よかったら教えてください
274 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 17:16:00.08 ID:cpOseG3V.net] 多次元配列の in-place な添字の入れ替え (transpose) って上手いやり方知られてますか? 多次元配列の各要素は一次元に配置されてると仮定して良いです (行優先でも列優先でも良いです)
275 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 19:01:36.72 ID:QNK25992.net] >>266-267 ありがとうございます とりあえず要素そのものじゃなくポインタかインデックスでやれば良いことに気づけました >>267 >片方だけソートしたら 両方ソートするイメージでした
276 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 20:38:48.11 ID:Cfq+H/IQ.net] >>269 縦横の二重ループで一つずつswapするしかないんじゃないかなー gslやgmtlはそうなってた
277 名前:デフォルトの名無しさん mailto:sage [2021/06/10(木) 21:10:03.36 ID:cpOseG3V.net] >>271 行列で言うと、上三角あるいは下三角の各要素を巡回して対応する要素と swap するみたいなことですよね? 多次元の場合も同じようにできますかね? 例えば3次元配列だったら、直方体を斜めに切って上三角錐か下三角錐の各要素を巡回するって理解で合ってますでしょうか
278 名前:デフォルトの名無しさん mailto:sage [2021/06/11(金) 11:50:48.69 ID:6MS9qCPq.net] CMakeについてもこのスレでいいの?
279 名前:デフォルトの名無しさん mailto:sage [2021/06/11(金) 12:12:28.01 ID:lhS8myn8.net] ちょっと違うね スレないんなら立てたら?
280 名前:デフォルトの名無しさん mailto:sage [2021/06/11(金) 15:24:20.00 ID:6w8Pdydz.net] スレ検索したらmakeスレなんて無いんだな 確かにここ10年位makefileなんて書いたことないけど…
281 名前:デフォルトの名無しさん mailto:sage [2021/06/11(金) 17:20:45.97 ID:6MS9qCPq.net] VSCodeで書く時は便利なんで・・・
282 名前:デフォルトの名無しさん [2021/06/12(土) 18:33:47.62 ID:ghBnzS2R.net] 過去に make 使ったら負け ってスレがあった
283 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 18:44:06.98 ID:uNQxUpm0.net] まあ今どきMakefileなんて人間様が書くもんじゃないし
284 名前: mailto:sage [2021/06/12(土) 20:02:28.17 ID:bG62sF4n.net] >>278 え?
285 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 20:28:22.70 ID:uNQxUpm0.net] え?
286 名前:蟻人間 mailto:sage [2021/06/12(土) 20:35:26.24 ID:bymgAWyc.net] 立ててみた。活用してね。 ビルド自動化ツールCMake Part.1 https://mevius.5ch.net/test/read.cgi/tech/1623496111/
287 名前:デフォルトの名無しさん [2021/06/12(土) 20:57:53.25 ID:1iQypGIZ.net] cmakeってすごいよね Makefile作れるだけかと思ってたらVisual Studioのソリューションファイルなんかも生成できて驚いた
288 名前:蟻人間 mailto:sage [2021/06/12(土) 21:13:38.88 ID:bymgAWyc.net] >>282 CMakeはGitHub Actionsと組み合わせると、ビルドとテストが自動化できて最強なんだよ。 コマンドラインで出来るめんどくさい仕事は自動化してほしいよね。
289 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 21:40:08.27 ID:sKjH8uh5.net] AutomakeもそううだがCMakeはなんでそんなことができるのか原理がわからん……
290 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 21:43:46.98 ID:txLE/1e4.net] mesonとかautotoolsとかのビルドツール共用でも良かったかな
291 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 21:49:00.69 ID:sKjH8uh5.net] ていうかそもそもVisual Studioのslnファイルの仕様とか公式に公開されていましたっけ
292 名前:蟻人間 mailto:sage [2021/06/12(土) 21:52:27.12 ID:bymgAWyc.net] >>286 中身見てごらん。テキストファイルだよ。
293 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 22:04:02.95 ID:o9BWFjAs.net] せっかくスレ作ったのにこちらで話してる
294 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 22:05:38.91 ID:sKjH8uh5.net] >中身見てごらん。テキストファイルだよ。 ヒエッ…、、、ブラックスワン理論…!
295 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 22:06:14.61 ID:Ap+0oKF5.net] バージョン変わるとすぐ壊れるがな。 dockerで環境揃えてmake使った方がよっぽど安定するわ。
296 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 22:27:19.91 ID:7X99TIl2.net] >>286 全部のタグを説明するリファレンスのようなものがあるかどうかは知らんけど、ある程度はドキュメント書かれているよ。
297 名前:デフォルトの名無しさん mailto:sage [2021/06/12(土) 22:33:32.97 ID:gSM3EPqA.net] >>286 マイクロソフトってそう言うドキュメントは結構まめに公開してるよ https://docs.microsoft.com/en-us/visualstudio/extensibility/internals/solution-dot-sln-file?view=vs-2019
298 名前:デフォルトの名無しさん [2021/06/12(土) 23:44:11.11 ID:l5AvwX9O.net] M$にベンダーロックインされる。
299 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 00:08:56.86 ID:nx3q3d7E.net] sln作らなくても最近のVisualStudioは直接cmakeプロジェクト読めるぞ
300 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 03:39:36.78 ID:8vbdM5AU.net] 新しいプロジェクトするならmesonを試したいなー
301 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 10:14:32.44 ID:exUpBE38.net] GYPには期待したんだがもう先がないな。
302 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 13:41:01.17 ID:NE9anLMi.net] メンバの構築 (コンストラクタの呼び出し) を後で行いたい なんでこれしきのことができないんだろうか 「ポインタ使え」はナシね これしきのことにポインタて笑って感じなんで
303 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 13:44:02.04 ID:5F9QidAB.net] C++では、デバッグモードと本番モードの切り替えってどうやるのが普通ですか? 今は、実行時に渡す環境変数で切り替えてます
304 名前:デフォルトの名無しさん [2021/06/13(日) 14:05:32.61 ID:zIllxi6t.net] ビルド時にバイナリ自体を分けるのが多いような
305 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 15:41:03.56 ID:NZ4aFVGn.net] >>297 他の言語の多くは参照型がデフォなんだから、同じことをC++でやりたいのなら他の言語の参照型に相当するポインタを使うのは当たり前じゃん。 どうせポインタよく分からないとかスマポも知らずにポインタめんどくさいとか思ってるからポインタ使いたくないんでしょう?このスレで笑われるのは君の方だよ
306 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 16:45:02.61 ID:MMKkdcax.net] まあスマポが他の言語みたいにスマートでもなんでもないゴミみたいな記述法だからなw
307 名前:はちみつ餃子 mailto:sage [2021/06/13(日) 17:11:16.17 ID:tRZIM+Qs.net] >>298 デバッグモードというのは具体的に何をするモードのことを言ってるの? 一般的に C++ 関連の用語として言うときのデバッグとリリースの違いはコンパイル時のプロジェクトを分けて 実行バイナリ自体が異なるものになるくのが普通だし、 Visual Studio とかを使ってたらリリース版とデバッグ版はそのように分かれるようになってる。 そういう運用の仕方についての質問ではなく、たとえば 「いざというときに現場でデバッグに使えるモードを仕込んでいるけど そのモードへの隠しスイッチはどうあるべき?」 みたいな切り替え方をどうすべきかだけの質問なのかな? もしそうなら環境変数でもコマンドラインオプションでも自然だと思う。
308 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 17:15:24.12 ID:Ciq9mmv0.net] >>301 言語の成り立ちや目的が違うからな そう思う人は他の言語を使えば良い
309 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 17:23:14.98 ID:exUpBE38.net] 「スマート」がなんで「記述法」にかかるんだろう。記述法にそんなもんあるのか?
310 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 17:33:42.92 ID:nx3q3d7E.net] C++標準としては「NDEBUGマクロで切り替えろ」じゃないの
311 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 17:58:03.62 ID:y2s9578f.net] >>297 std::optional で。ポインタ使うのの何が嫌なのかわからないけど。
312 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 17:58:55.99 ID:y2s9578f.net] >>298 それで切り替えできてるならいいじゃないの。人の数だけある「普通」とかどうでもよくない?
313 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 18:41:43.91 ID:ZxtyD0qd.net] >>300 ポインタは参照型じゃなぁぁぁぁい!w
314 名前:はちみつ餃子 mailto:sage [2021/06/13(日) 18:42:59.35 ID:tRZIM+Qs.net] >>308 だから「相当する」という語が付いてるんだろ?
315 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 18:47:32.61 ID:5F9QidAB.net] >>299 ,305,307 ありがとうございます
316 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 19:00:04.06 ID:cbxmrD1A.net] C++に関係したフォーラムや掲示板で、一番人が多いとこってどこですか? 海外のサイトでも可です このスレで質問することも多いのですが、アルゴリズムに絡んだ質問だったりするとなかなか回答頂けないので
317 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 19:51:51.12 ID:4vlvBmrw.net] 多次元配列の a[2][3][4] って記法、各次元の長さが x, y, z だとすると *(a + 2*y*z + 3*z + 4) を計算してるの? 意味的に一緒かというよりは、実際そういう実装になってるのか知りたいです かけ算の数が小さくなる工夫みたいのってされてるんですか?
318 名前:蟻人間 mailto:sage [2021/06/13(日) 20:00:41.15 ID:otNLJkw4.net] >>312 CPUに合わせた最適化はされてるよ。例えばx86 CPUではメモリーアドレッシングという計算が得意。まあ、コンパイラが吐くアセンブリを見るといいよ。
319 名前:はちみつ餃子 mailto:sage [2021/06/13(日) 20:15:02.56 ID:tRZIM+Qs.net] >>311 質問なら Stackoverflow とか Teratail とか。
320 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 20:28:49.46 ID:4vlvBmrw.net] >>313 ありがとうございます > 多次元配列の a[2][3][4] って記法、各次元の長さが x, y, z だとすると *(a + 2*y*z + 3*z + 4) を計算してるの? というのは大体どんな処理系でもそうで、 > かけ算の数が小さくなる工夫みたいのってされてるんですか? ここは処理系による高速化がされてるということですね つまり、大抵は > 2*y*z + 3*z + 4 に相当する部分を自分で (書いた関数とかマクロで) 計算して a に加えるよりは、a[2][3][4] とアクセスする方が速いんですかね? >>272 の、多次元配列の添字の入れ替えを in-place でやりたいという話で、こういう疑問に行き当たりました
321 名前:はちみつ餃子 mailto:sage [2021/06/13(日) 20:44:32.87 ID:tRZIM+Qs.net] >>315 それを自分で判断できない知識レベルならコンパイラに任せたほうが確実に良いよ。 「早すぎる最適化は諸悪の根源」とか「実測せよ」というよく知られた格言がある。 仮にちょっとした書き方で高速になるのだとしてもそれによって全体が読みにくいコードになってたら 改善するのが大変になって結果的にあまりよくないコードになってしまいがち。 処理速度が足りないのなら足を引っ張っているのはどこなのか 完成したプログラムを測定してから問題個所を改良すべきというのが先人の教え。
322 名前:蟻人間 mailto:sage [2021/06/13(日) 20:51:49.27 ID:otNLJkw4.net] >>315 どうやれば高速化するかは、実際のコードで実測とアセンブリみないと解析できない。掛け算の代わりに足し算で計算できる場合はそうした方が早いかもしれない。 x86 アセンブリの場合、MOD eax, [ecx+ebx*2]のように一語でアドレス参照できる場合がある。 高速化手法には、他にもSIMDもあるし、マルチスレッドもある。
323 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 21:02:57.88 ID:TY7uaTz0.net] >>297 C++11だとnewでメモリだけ最初に確保しといて、も一回 new で そのメモリ指してコンストラクタ走らせるってやり方? ポインタ遮蔽するような template書けば良さそうだけど。
324 名前: mailto:sage [2021/06/13(日) 21:06:50.91 ID:Ln9XBzss.net] >>308 イコールとはいいませんが、ニアリーイコール、同じようなものですよ‥‥
325 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 21:08:32.23 ID:Q2x3/Bx2.net] >>318 わざわざ自分で書かなくてもvectorがちょうどそんな動作してるよね
326 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 21:43:42.51 ID:4vlvBmrw.net] >>317 ありがとうございます in-place だと ○ 作業用メモリが必要ない ○ 全要素の半分だけ一回ずつ訪れれば良い ☓ 要素アクセスは自分で書いた関数なりマクロなりで行う必要がある out-place だと ☓ 作業用メモリが必要 ☓ 作業用領域にコピーして元の配列に戻すので各要素を二回ずつ訪れる必要がある ○ 要素アクセスは高速 て感じなので、やってみてどっちが良いか決めます
327 名前:デフォルトの名無しさん mailto:sage [2021/06/13(日) 22:27:55.12 ID:UWNgHhx2.net] 俺がC++をこよなく愛する理由のひとつがとにかく長年の積み重ねのおかげで コンパイラが激烈に賢いことだ 他の、たとえばJavaやらそれから派生したKotlinなんかでコード書いてて 「こんぐらいはコンパイラが最適化してくれるっしょ」とかルーズに書いて 実際に展開されたバイトコード見て絶望したことは数えきれない
328 名前:はちみつ餃子 mailto:sage [2021/06/13(日) 22:41:11.48 ID:tRZIM+Qs.net] Java の場合は JVM の側で最適化したりするからバイトコードはそんなに頑張らないらしいよ。
329 名前:はちみつ餃子 mailto:sage [2021/06/14(月) 02:15:01.87 ID:fvxG9/iR.net] makefile (GNU Make) の使い方の質問はどのスレで聞いたらよいんですかね?
330 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 07:14:11.60 ID:C+gz3c8V.net] >>297 普通に破門 おまえはポインタを使うなではなくC++を使うな 二度とこの世界に戻ってくるな
331 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 08:03:40.16 ID:nv+G1IlK.net] CMakeのスレ使えば?
332 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 08:09:35.27 ID:/kKjPBzj.net] >>297 誰もメリット感じな
333 名前:「から実装しないんだろ。 ポインタに対するメリットは? [] [ここ壊れてます]
334 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 08:35:37.07 ID:wsn+oRmt.net] みなstd::unique_ptrを思いついているが質問の仕方が気に食わないのでわざと回答しない
335 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 08:43:01.39 ID:6p9bp5Dj.net] 「これしきのことにポインタ」とか言ってるくらいだから>>297 にとってポインタのハードルがものすごく高いんだろう。
336 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 10:09:52.82 ID:C+gz3c8V.net] w
337 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 10:36:17.05 ID:wsn+oRmt.net] そうは言っても、コンストラクタでしかプロパティ設定できない不親切なクラスを仕方なく使う羽目になることは結構あるでしょ
338 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 10:44:09.11 ID:FpnA+nhS.net] RAII分かってるならそもそもコンストラクタ呼び出した後に2phaseでメンバ構築やろうなんて思わないから、質問の意図がわかんねーんだよな
339 名前:デフォルトの名無しさん [2021/06/14(月) 11:25:21.25 ID:LnG83xz5.net] >>290 ++
340 名前:デフォルトの名無しさん [2021/06/14(月) 11:30:58.26 ID:LnG83xz5.net] >>311 stackoverflow
341 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 11:33:34.30 ID:C+gz3c8V.net] > このスレで質問することも多いのですが、アルゴリズムに絡んだ質問だったりするとなかなか回答頂けないので 知ってるがお前の態度が気に入らない というケースならいくつか思い当たるな
342 名前:デフォルトの名無しさん [2021/06/14(月) 11:36:44.15 ID:LnG83xz5.net] >>312 >多次元配列の a[2][3][4] って記法、各次元の長さが x, y, z だとすると > *(a + 2*y*z + 3*z + 4) を *(a + 4 + (3 + 2*y)*z) くらいのことはやってるよ
343 名前:デフォルトの名無しさん [2021/06/14(月) 11:40:50.95 ID:LnG83xz5.net] >>315 そういう話ならいちいち掛け算してるかとかその回数がとかよりも メモリキャッシュに乗ってるかどうかの効率の方が多きい
344 名前:はちみつ餃子 mailto:sage [2021/06/14(月) 17:34:14.74 ID:fvxG9/iR.net] 前後の命令の依存関係によっては多少高コストの演算でもパイプラインに隠れて全体としては それほど時間がかからないということも有りうる。 命令ひとつの実行コストだけでは評価できないから結局のところやってみてから計測するのが 手っ取り早いって話になる。
345 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 18:10:27.40 ID:riVdj5/n.net] >>312 現代の普通のコンパイラであれば当然最適化が行われる コンパイル時に決定可能な部分はコンパイル時に決定するし、 ループ内で変化がない部分はループの外で計算する のが普通 a[i][j][k] で一番ループの内側がkであれば a[i][j]まではループの外で行うし a[1][2][k] のような固定値であればa[1][2]まではコンパイル時に計算する メモリアクセス順は非常にパフォーマンス的には重要で a[i][j][k] を3重ループでアクセスする場合 ループの外側からi,j,kとするべき 言語上のいわゆる配列は最適化されやすいので普通は気にしなくていいが、 vectorやMatなど、外部定義の [] は基本的には遅いと思っていい コストが小さいとはいっても確実にコストは発生する 速度が非常に重要な場合では SIMD化、キャッシュ化、ループアンロールなどで最適化すべき その場合も、データ構造、アクセス順、アルゴリズムなど上位層の最適化が終わってから
346 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 22:36:37.28 ID:VOy4fGQR.net] vectorの[]だって配列へのアクセスしかしてないけどな。 インライン展開されるし範囲チェックもしてない
347 名前:デフォルトの名無しさん mailto:sage [2021/06/14(月) 23:49:54.30 ID:4pDx/Jk6.net] 素人質問ですみません クラスのメンバ関数は常に外で実装しますか?それとも、短いものはクラス宣言内に書きますか? 混在させて良いものかと迷っています(クラス宣言内に書くとinline指定になる事は知っています
348 名前:はちみつ餃子 mailto:sage [2021/06/15(火) 00:02:19.94 ID:t/bAz/vZ.net] >>341 どっちでもいいようになっているんだからどっちにするかは個別の判断による。 具体的条件を示してくれたらどちらが好ましいかの意見は言えるよ。
349 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 05:05:22.97 ID:UNOhr6//.net] template<class T, size_t N> using myarray = std::array<T, 2*N>; としたときに、関数 hoge を template<class T, size_t N> void hoge(myarray<T, N>); と template<class T, size_t N> void hoge(array<T, N>); でオーバーロードすることってできますか?
350 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 05:32:07.52 ID:d2euf9Bx.net] >>338 高コストという文言の意味がよくわからんが レイテンシが大きい命令はパイプラインを乱すぞ
351 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 05:35:15.36 ID:d2euf9Bx.net] >>343 2番目のオーバーロード関数はarrayにstd::を付け忘れてるのか? だとすると無理だと思うな std::array<int, 1> a; hoge(a); と呼び出したとき、N==2となるべきかN==1となるべきかの根拠がないから やってみてないけど つーか、おまえさんはやってみたのか?
352 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 05:40:17.26 ID:UNOhr6//.net] >>345 > 2番目のオーバーロード関数はarrayにstd::を付け忘れてるのか? すみません。そうです まだ試してないです 無理そうだなって思うんですが、昔「オーバーロード関数は機械にとってはそれぞれ別名関数だ」って話を聞いて、じゃあもしかしたら行けるかもと思った次第です
353 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 07:12:05.86 ID:9e5Yrhbb.net] すぐ試せることを自分で試さずに5chで聞くの良くないよ
354 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 07:54:52.19 ID:rGBATnAZ.net] >>341 templateのクラス書いてると、長くても中に入れちゃうから、でかいのバーンって そのままヘッダに入れても抵抗はないけど、templateでない場合でかい関数は普通に外に書くな。
355 名前:デフォルトの名無しさん [2021/06/15(火) 08:01:18.68 ID:d2euf9Bx.net] >>341 外 templateやstaticのように実装をヘッダファイルに書く場合も ヘッダファイルの中でプロトタイプと実装に分ける さらに実装は別ファイルにしてヘッダファイル内で#includeする 宣言だけからなるアウトラインを残したいから
356 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 08:19:37.29 ID:UNOhr6//.net] >>343 ,345-347 試して無理でした 言い方合ってるかわかりませんが、>>343 のやり方ではオーバーロードと関数テンプレートの差がないからでしょうか コンパイラに myarray を array と別の型だと思ってもらって、hoge をオーバーロードするテクってありますでしょうか
357 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 09:04:05.70 ID:9e5Yrhbb.net] >>350 継承でいけるんじゃね
358 名前:はちみつ餃子 mailto:sage [2021/06/15(火) 09:47:07.09 ID:t/bAz/vZ.net] >>350 using で作った別名と元の型を区別する方法があるかという意味でなら方法は無い。 using は「別名」を作っているだけであくまでも同じ存在。 オーバーロードできるように型を分ける方法があるかという意味でなら >>351 が提案しているように継承を使うのが簡単な方法。 template<class T, std::size_t N> class myarray : public std::array<T, 2*N> {}; みたいに書いて継承しつつ特になにも付け加えなければ事実上の別名でありつつ異なる型でもある。
359 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 10:24:24.93 ID:d2euf9Bx.net] template<class T, std::size_t N> class myarray : public std::array<T, 2*N> { using std::array::aray; }; コンストラクタも継承しとかないと使いにくくて困るぞ
360 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 10:25:47.44 ID:d2euf9Bx.net] std::array<T, 2*N>::arrayか この件のみ動作確認しないポリシーなんでやりづれえ
361 名前:デフォルトの名無しさん [2021/06/15(火) 15:04:54.99 ID:dTl1pSLY.net] >>349 迷惑なやつだな
362 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 15:40:54.02 ID:UNOhr6//.net] >>351 ,353-354 なるほど ありがとうございます > この件のみ動作確認しないポリシー てどういういみでしたっけ?
363 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 15:43:28.83 ID:UNOhr6//.net] コンストラクタさえ継承しとけば、元のクラスとほぼ同じ使用感で使えるんですかね? 試しきれないので未知の困難に直面しそうで結構不安です
364 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 15:44:46.76 ID:d2euf9Bx.net] >>355 何が?
365 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 16:21:53.57 ID:9e5Yrhbb.net] >>356 多分、自分で確認もせず書き込むようなやつには同じく動作確認なんかしてやらねーよ、
366 名前:チてことだろ [] [ここ壊れてます]
367 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 18:25:24.86 ID:yoH1yiay.net] どうでもいいけど変数テンプレートの四則演算って推論の邪魔するような
368 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 20:42:15.88 ID:GdaBtgkC.net] >さらに実装は別ファイルにしてヘッダファイル内で#includeする これはやりすぎだろ #include先に何書いてるかわからんから結局読まなきゃならん 空行とコメントで上下に分ける方がマシ
369 名前:デフォルトの名無しさん mailto:sage [2021/06/15(火) 21:00:10.82 ID:9e5Yrhbb.net] それは非テンプレートなクラスでも一緒だと思うけど
370 名前:デフォルトの名無しさん mailto:sage [2021/06/16(水) 06:00:46.73 ID:KGe9Xsu1.net] >>361 その論法はヘッダファイルそのものを否定する考えだな
371 名前:361 mailto:sage [2021/06/16(水) 21:17:19.71 ID:vMisLWvQ.net] 結局読まなきゃならないのは一緒だよ、当たり前 それでも、何か所にも同じのを書くのが嫌だから#includeなんじゃないの? 俺は一か所からのみ#includeするのを否定してる
372 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 05:36:20.94 ID:qVo1n1YK.net] 何か所にも同じのを書くのが嫌なら テンプレートでない関数をプロトタイプと実装に分けただけで難癖つけるのか?
373 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 10:01:25.56 ID:4N0CEvnv.net] まぁヘッダのインクルードの仕方はそれぞれだからなぁ 自作ヘッダ内では一切インクルードしない(それの前に必要なヘッダをすでにインクルードしてる前提)ってのもある ただその戦略なら、テンプレートがインスタンス化される直前にその実装が書かれたやつインクルードすればいいだけなんだが
374 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 10:28:32.50 ID:fU6donkc.net] 多分同じ奴だと思うが、数スレ前から多次元配列を自力でどうこうしようとしてる奴、悪いこと言わんから外部ライブラリ使うとけ 今の時代、行列とかテンソルの計算は並の人間が書いた C/C++ じゃ絶対に Python (NumPy) その他に敵わんと思う まあ C/C++ の多次元配列ライブラリも群雄割拠で何が何だか全く分からないんだが STL に多次元配列が中々入らない理由もこれかな
375 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 10:29:56.26 ID:fU6donkc.net] つーか入ったところで大したもんにはなり得ないか 行列の分解とか掛け算を STL が担うのはあり得んしな
376 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 10:31:47.16 ID:kZP6q6xj.net] >>365 難癖もクソも普通にC/C++の欠点でしょ フロッピーディスクの時代の遺物よ
377 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 10:34:24.84 ID:qVo1n1YK.net] >>369 別におまえさんにC/C++を使ってくれなんて頼んでない 嫌いなら出てってもらって構わない
378 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 10:36:52.42 ID:kZP6q6xj.net] >>370 誰が嫌いなんて言った? 欠点を差し引いてもメリットがあるから使ってるんだし、欠点は欠点として認めないと進歩しないよ
379 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 10:48:03.95 ID:EQR7Wr8E.net] 質問です #define A L"xyz" #define B L"www" を結合するとき #define C AB じゃだめなんですか? #define D A(B) ですか? それとも #define E A"www" ですか?
380 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 10:51:16.93 ID:ADII7SgV.net] #define C A B じゃね
381 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 10:52:13.35 ID:qVo1n1YK.net] >>371 欠点は欠点として認めるって具体的にどうしてるんだ? プロトタイプを一切しない、のような公害か?
382 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 11:09:25.36 ID:4N0CEvnv.net] >>374 いや昔の貧弱な環境でもビルドできるように、って制約が無きゃもうちょっと違う形だったんじゃないの 今みたいにヘッダが肥大化しがちで各ソースごとに同じ解析しなきゃならないのは不自然ではある IDEやコンパイラが賢いおかげでそこまでビルド時間酷くはならんようだけど >>367 行列とかに関しては特に、C++のみで限界までチューニングしたってSIMD使ったコードにはまず勝てない(さらに言えばGPGPU使った方が、大きい行列ではもっと速い それらを汎用化して使いやすくするのは可能だろうけど、そんなハード依存が激しいものを標準に入れるのか、それともハード依存は無いがめっちゃ半端なものを作るかの二択になるからでしょ
383 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 11:16:45.59 ID:Wy62wyA7.net] >>372 #define C A##B
384 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 11:31:03.61 ID:qVo1n1YK.net] >>375 具体的にどうしてるんだ? と聞いてるんだが 答えたくないならいいよ
385 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 11:38:23.32 ID:4N0CEvnv.net] IDも知らんのかこいつは
386 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 11:48:01.35 ID:qVo1n1YK.net] 日本語でおk
387 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 12:15:01.57 ID:fU6donkc.net] >>375 はい そう申しております
388 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 12:21:37.22 ID:I9fxtS5z.net] >>379 375「俺は371じゃないから質問に答えろと言われても知らない」
389 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 12:33:13.95 ID:qVo1n1YK.net] 横レスにしても頓珍漢すぎるだろ 今、横レスとして読み直したが俺にアンカー振られている意味がわからない
390 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 12:36:53.30 ID:4N0CEvnv.net] >>369 に噛み付いてるんだから欠点じゃないと言いたいんだろ? 頓珍漢はお前だ(>>374 でも相当おかしな事言ってるが >>380 すまん直後の書き込み読んでなかった
391 名前:デフォルトの名無しさん mailto:sage [2021/06/17(木) 12:43:39.21 ID:qVo1n1YK.net] >>383 また例のオウム返し野郎か 何がおかしいのか説明できないやつがハッタリかますんじゃねえ
392 名前:361 mailto:sage [2021/06/17(木) 20:43:21.47 ID:3vRllUUS.net] >>365 俺の>361,364の一体どこをどう読めばそんな解釈ができるのか教えてくれよ 俺が否定してるのはこれ↓ >さらに実装は別ファイルにしてヘッダファイル内で#includeする これは全然「テンプレートでない関数をプロトタイプと実装に分けただけ」じゃないよ (藁人形論法ってやつか?これ)
393 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 00:22:44.11 ID:h1swrzIp.net] ポインタはchar * const p = q; とでも書かないとpがconstにならないが char& c = *q; と書いたらそんなリスクを回避できる 革命的前進
394 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 00:25:25.92 ID:h1swrzIp.net] >>376 ハア? #define C(A, B) A##B にしないと駄目なんじゃ…… もっともK&Rの頃のCなら #define C A/**/B と書くことはできたっぽい
395 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 08:34:36.86 ID:R4m5mk7U.net] >>372 のAとBを連結するなら>>373 でいいだろ。括弧でくくった方がいいかもしれんが。 ##は用途が違う。
396 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 09:49:26.06 ID:24jxp6EK.net] 実装も書いてあるヘッダファイルって src に置くの? include に置くの?
397 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 09:57:10.61 ID:LzkNSM+F.net] boost のライブラリって、一度入ったら時代遅れになっても取り除かれないんですか? それとも boost の全貌を把握してる委員会みたいのがあって、ちゃんと選別みたいなことをしてるんですか? 今どきムーブセマンティックに対応してないデカいコンテナクラスを見つけて、そういう疑問を持ちました
398 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 10:08:12.10 ID:kJSePQf1.net] >>385 俺は > 何か所にも同じのを書くのが嫌なら > テンプレートでない関数をプロトタイプと実装に分けただけで難癖つけるのか? と言ったんだ 二行目だけ切り取ってきて人のこと藁人形とは藁わせてくれるやつだな
399 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 10:17:41.61 ID:7GC3MWRE.net] >>385 純粋に気になるんだけど、例えば俺が>>366 で書いたようにテンプレートの実体化が起きる前に関数、メンバ関数の実装を分けてインクルードすることは出来るけど 実体化が起きる翻訳単位では必ず実装が必要になるよね?(テンプレートの分離コンパイルは出来ないという問題から) クラステンプレートのポインタや参照しか使わない翻訳単位では、例えばiosfwdみたいに前方宣言しか書いてないヘッダを使うことで、ビルド時間減らせるかもしれんけど そういう意味ではクラステンプレートの定義書いてるヘッダで
400 名前:、メンバ関数の実装を書いたヘッダをインクルードするのは別におかしくはないと思うんだが [] [ここ壊れてます]
401 名前:デフォルトの名無しさん [2021/06/18(金) 12:27:14.41 ID:7Huy+AZL.net] >>389 src に .hpp が置いてあるプロジェクト観たことあるけど かっこ悪いと思った
402 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 12:47:25.93 ID:24jxp6EK.net] include に置いてあるファイルに実装めっちゃ書いてあってももちろん嫌じゃないですか?
403 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 12:54:04.57 ID:kejK9s3z.net] いやも何も、テンプレートは明示的実体化して使えるテンプレートパラメータを制限でもしない限り、ヘッダに実装するしかないんだよ 可読性の問題を気にしてるなら拡張子変えればいい ヘッダだからって.hや.hppじゃなきゃいけないなんて決まりは無いしinclude(フォルダかグループか知らんけど)直下に置かなきゃいかんわけでもない そのくらい自分で工夫しろ
404 名前:デフォルトの名無しさん [2021/06/18(金) 13:18:46.12 ID:7Huy+AZL.net] .obj で分割するメリットって .exe が巨大化しないためってのもあるけど テンプレ使うと各 .obj 全部に同じバイナリーが増殖しない?
405 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 13:51:38.82 ID:kejK9s3z.net] 多分だけど、今時の環境だと一度他の翻訳単位で実体化されたものは再利用するんじゃなかったかな
406 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 14:28:08.43 ID:ru+U9KL5.net] リンク前に判るの? リンク時に同じ名前で同じ引数ならまとめるの? 怖くない?
407 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 14:31:16.93 ID:kJSePQf1.net] lexical phase 9だな
408 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 20:05:16.88 ID:Ipfg6SU0.net] >>391 論旨変わってないだろ、何が切り取りだか で、お前のその変な疑問がどこから出たのか聞いてるんだけど >>392 「そういう意味」がどういう意味なのかよくわからない .hに宣言しか書いてないからコンパイル時間が減るんであって、 .hで定義をincludeしたら減らないよ?
409 名前:デフォルトの名無しさん mailto:sage [2021/06/18(金) 20:29:54.81 ID:kejK9s3z.net] >>400 テンプレートの話やろ? 翻訳単位のどこかに定義(実装)が必ず要るんだぞ あるソース(翻訳単位)においては不完全型でいいんなら、そこで使うヘッダは前方宣言だけでいい(クラス定義は要らん)って書いたじゃん クラス定義が要るんならそれは実体化を伴うんだからメンバ関数の実装ヘッダに書いてなきゃリンカエラー出るぞ
410 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 06:14:13.07 ID:BH9bYKW9.net] >>400 だから1行目を読め 読みたくないなら逃げるのはおまえさんの勝手だが 逃げた事実は消えないぞ
411 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 06:30:02.69 ID:o72o+RiW.net] >>390 だめなboostライブラリというのは、そりゃ山ほどある メンテナという概念は一応あろうが
412 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 07:50:07.39 ID:do8R3N0p.net] >>398 YES実際恐ろしい "a.cpp"に class Foo { void some_method() const { return 3.0; } }; "b.cpp"に class Foo { void some_method() const { return 4.5; } }; int main() { Foo x; printf("%f\n", x.some_method()); } とか書いてリンクして実行したら3.0と表示されることがある ビルド中に警告とかは無し(於VC++ 2010 というわけでクラス定義は極力ヘッダファイルに書くのが正しいい 二つのFooクラスの定義を同時にincludeしたら確実にビルドエラーになってワカル どうしても.cppファイル側にクラスの定義を書くときは無名namespaceで囲うべきや (名前付きnamespaceは名前の重複についてクラス定義ほど検査が厳しくないのであまり解決策にならない
413 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 08:09:04.24 ID:do8R3N0p.net] 今ジッケソしたがVC++ 2019でも同じだぬ、 "a.cpp" #include <stdio.h> class Foo { public: double some_method() const { return 3.0; } }; double get_Foo() { Foo y; return y.some_method(); } "b.cpp" #include <stdio.h> extern double get_Foo(); class Foo { public: double some_method() const { return 4.5; } }; int main() { printf("%f\n", get_Foo()); Foo x; printf("%f\n", x.some_method()); } 実行結果: 3.000000 3.000000 4.5どこ行った;;;
414 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 08:55:28.76 ID:MSAvpN3e.net] 初歩的なことかもしれませんが質問させてください。 以下の3ファイルがあるとして、src.cpp をコンパイルしようとすると失敗します。 hoge の myclass に対する特殊化を file2.hpp でしてるだけだから OK だと思ったのですが、無理でした。 一方で、file1.hpp の中身を file2.hpp の下の方にコピペしたらコンパイルできます。 この、hoge の特殊化を file2.hpp でしてるという考え方はどう間違ってるのでしょうか。 // file1.hpp template<class T> void hoge(T); template<class T> void fuga(T x){ hoge(x); } // file2.hpp #include"file1.hpp" #include"myclass.hpp" template<class T, int N> void hoge(myclass<T, N> x){ ... } // src.cpp #include"file2.hpp" int main(){ myclass<int, 10> x; fuga(x); }
415 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 09:03:50.50 ID:N/imZiDN.net] >>406 無理でしたとは?コンパイルエラー?エラーメッセージは?
416 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 11:19:08.00 ID:xVp2TfT/.net] それ多分特殊化じゃなくてオーバーロード?(違ってたらすまん hogeの<T>を受け取る奴で実体化した後にmyclass受け取る奴が出てくることになる myclass版の前方宣言をfile1.hpp(fugaより前)に書くか、fugaの実装をfile2.hppのインクルードより後にすればいける、と思う
417 名前:はちみつ餃子 mailto:sage [2021/06/19(土) 14:35:39.56 ID:/f53/cxR.net] >>406 それは >>408 が指摘する通りオーバーロードになってる。 オーバーロードの解決方法は複雑なんで私もちょっと自信はないんだけど、 オーバーロードの候補の内で実引数の型と完全に同一 (または実引数の型に cv 修飾したもの) のものがあれば、 それの優先度はテンプレート引数のマッチより高いので曖昧さは生じずに解決できるのが正しい。 そんで >>408 がいう > hogeの<T>を受け取る奴で実体化した後にmyclass受け取る奴が出てくることになる というのはたぶん関係ないと思う。 Two phase name lookup のルールが適用されるはずだから fuga 内での hoge の呼出しは その時点では解決を試みられず、 main 内での fuga の呼出しが有った時に fuga の実体化が起こってそのときに hoge も実体化されるので 宣言の順序にかかわらずどちらの hoge も候補になるはず。 なので include がどうこうというのとは関係なく file2.hpp のほうの hoge が問題なく呼び出されるべきで、 >>406 に間違いはないと思う。 手元に入れてないから動作確認できないんだけど古い MSVC は Two phase lookup の実装が おかしかったとか聞くからそのへんで何か問題が起こってるんじゃないか? GCC や Clang だとかなり古いバージョンでも特に問題なくコンパイルできてる。
418 名前:デフォルトの名無しさん [2021/06/19(土) 15:55:55.01 ID:zDrgWeBe.net] >>405 リンクする順番変えたら 4.5 になったり 3.0 になったりするかもしれないししないかもしれない
419 名前:はちみつ餃子 mailto:sage [2021/06/19(土) 16:47:38.21 ID:/f53/cxR.net] >>396 古典的なツールチェインでは同一のものがそれぞれの翻訳単位に作られる。 その上でリンク時に同じものは同じに統合される。 それが嫌だという場合にはテンプレートには明示的実体化という仕組みがあって、 暗黙的な実体化を抑制する仕組み (extern template) とセットで使うことで テンプレートの実体をひとつの翻訳単位にまとめることは出来る。 当然だが個別に指定するのはめんどいし、 いまどきの処理系は賢いので、あまり使われてないと思う。
420 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 18:01:09.17 ID:xVp2TfT/.net] >>406 ,>>408 うろ覚えだったのでスマンコ というか自分がその手の順序依存を経験したのはVC2008-2015あたりまでだった気がする 最近のだとC++標準への準拠の設定(コンパイルオプション/Zc:twoPhaseとか)も影響するはず
421 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 18:07:00.49 ID:xVp2TfT/.net] 間違えた、>>406 ,>>409 2017あたりまで標準への準拠のオプション(名前不明)は指定しないと有効にならなかった気がする、2019では既定
422 名前:デフォルトの名無しさん mailto:sage [2021/06/19(土) 18:48:12.63 ID:xVp2TfT/.net] /permissive- やった(VS2017 2015以前なら>>408 のような対策するしかないと思う
423 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 04:37:05.08 ID:aJXir9C9.net] >>407 失礼しました 短縮して書くと undefined reference to 'void hoge<myclass<int, 10>>(myclass<int, 10>)' というメッセージが出ます コンパイラは g++ 11.1.0 です 用語の使い方が正しいか自信がありませんが、 file1.hpp 内で hoge の宣言と hoge を呼ぶためのユーティリティ関数 fuga の実装をしておいて、後から必要に応じて具体的な型について hoge の実装を書ける、という方がすわりが良いのですが、こういう考え方は間違っていますか fuga は型によらず hoge を呼ぶための関数なのでその実装を後に回したくない、という思いもあります
424 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 07:43:07.12 ID:vxtAtGft.net] C言語の double _Complex と C++ の std::complex<double> って実部虚部の並び方とか一緒ですよね? ヘッダファイル aaa.h で宣言されてる double _Complex * をとる関数に std::complex<double> * を渡したいのですが、やり方がわかりません。 #define 〇〇 std::complex<double> #include<aaa.h> みたいにできると想像してるのですが、合っているでしょうか?
425 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 08:46:26.25 ID:D2z+V4uq.net] >>416 _Complexはただのdouble型変数なのでstd::complex<double>と互換性なし
426 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 08:59:29.33 ID:vxtAtGft.net] >>417 メモリレイアウトから違うのですか? では、double _Complex * をとる関数に std::complex<double> * を渡すことはできないということですか?
427 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 09:04:23.23 ID:D2z+V4uq.net] はい
428 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 09:11:24.89 ID:vxtAtGft.net] エ!? _Complex って std::complex の後にできたんじゃありませんでしたか なぜ、実部と虚部がメモリ上に連続で置かれているという設計にしなかったのでしょうか……
429 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 09:29:15.86 ID:yGlwqyqX.net] 作りが似ている、ということと 互換性が保証されている、ということは同じじゃないぞ 保証があるか否かは規格票で確認することで主観が入る余地はない 俺が見た範囲では保証するとは書いてなかった
430 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 09:29:35.37 ID:D2z+V4uq.net] _Comolex変数の実部と虚部をそれぞれcreal(), cimag()で取得してstd::complex<double>変数にセットするしかない
431 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 09:35:42.79 ID:D2z+V4uq.net] _ComplexがC99でstd::complex<T>がC++03
432 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 09:53:39.49 ID:Q4Tfx6ZF.net] >>415 >>406 に嘘書いてないか?
433 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 10:06:25.46 ID:vSSpHRy4.net] std::complex<double> *hoge; double _Complex *p = (double _Complex *)&hoge[0];
434 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 10:06:45.88 ID:76n7YcAv.net] >>424 すみません どこか矛盾しますでしょうか 手元でコンパイルしてみて、そうなりました
435 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 10:22:51.51 ID:Q4Tfx6ZF.net] >>408 は試してみた?
436 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 10:33:37.36 ID:76n7YcAv.net] >>427 はい >>408 様の仰る「fuga の実装を後に書く」というのが、>>406 に書いた「下の方にコピペしたら」というのです そして、それらのことを踏まえて、>>415 に書いたような疑問を持ちました ところで嘘というのはどういうものでしょうか なにか矛盾しますでしょうか
437 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 11:18:41.97 ID:Q4Tfx6ZF.net] hogeの実装(関数の中身)を実際は書いてなかったとか、何か事実と違うことがあるんじゃないかと思った だけ >>415 に書いてある理由なら、同じコンパイラであればどこか妥協するしかない気が fugaの前方宣言だけはfile1に残して、実装を別のヘッダにして後からインクルードするとかは?(>>408 で言ったのはそういうことなんだけど
438 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 14:29:11.44 ID:vxtAtGft.net] >>421-422 今調べたら、C側は実部虚部というメモリレイアウトを保証していて、std::complex 側は C の複素数と同じメモリレイアウトを保証してるようですね >>423 すみませんCの方が早かったんですね >>425 ありがとうございます 暗黙のキャストがなぜ許されないのかはまだよく分かっていませんが、キャスト自体は可能なようで、double _Complex (あるいはそのポインタ) をとる C 言語関数に std::complex<double> (あるいはそのポインタ) を適切にキャストして渡すのは問題ないようになってると理解しました
439 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 15:33:53.67 ID:yGlwqyqX.net] >>430 その件について ISO/IEC 9899でC++という文言に言及するか ISO/IEC 14882でCという文言に言及しているか? 430に書かれている限りでは「似ている」だけだが それからC++03は2003年にC++98のバグ修正をしただけだから C99より古いぞ
440 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 15:42:44.16 ID:iNrFbyNf.net] 良スレ気体age
441 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 16:06:01.76 ID:vxtAtGft.net] >>431 いや、すみません。逆に「似ている」とはどういう意味でしょうか 例えば std::complex については eel.is/c++draft/complex.numbers の記述からしてメモリレイアウトは実部虚部と決まってるわけですが、これはソースとは見なせないんでしたっけ?
442 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 16:11:41.02 ID:vxtAtGft.net] >>431 > それからC++03は2003年にC++98のバグ修正をしただけだから > C99より古いぞ ですから、 >>430 > Cの方が早かった のでは? あと>>433 は「std::complex は C の複素数型と同じことを保証する」という記述は含みませんね ただ、この場合メモリレイアウトが同じであることの他に要請するべきことってありますっけ?
443 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 16:13:04.04 ID:vxtAtGft.net] >>431 ,434 > ですから、 > >>430 > > Cの方が早かった > のでは? すみません 間違えました ごっちゃになってました これは取り消します
444 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 17:28:56.50 ID:KYXAfitG.net] https://stackoverflow.com/questions/55563217/do-complex-types-in-c99-behave-like-stdcomplex-in-c ここを読むとメモリレイアウトは同一みたいなんだよね。むりやりキャストしても問題なさそうな気がするけど
445 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 17:50:06.69 ID:CGp4yDz+.net] 本質的なデータはdouble2つ組だし、順序も普通は実部→虚部だろうし、わざわざパディングや別の変なメンバ混ぜることも考えにくいし たまたまレイアウト一致する可能性は現実的に高いだろうけど 規格が保証してるかどうかはまた別の話かな
446 名前: mailto:sage [2021/06/20(日) 17:59:57.69 ID:DQg/pXKj.net] もう C は C89 で止めれ C++ は C89 だけ受け付け可能であれば、あとは好きに変えてもらってもかまわない
447 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 18:02:34.31 ID:D2z+V4uq.net] C/C++の複素数の構造体・クラス間の変換関数を規格として用意してもらうしかない
448 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 18:23:00.50 ID:zi1IwKwq.net] インテルコンパイラの最適化オプションO2とO3で計算結果が変わって、問題を起こしている箇所を見つけようと思ってるんですが、 $ icpc -O3 src.cpp -lhoge とコンパイルしてる場合、当然 src.cpp に問題があるのであって別でビルドされたライブラリ hoge は無関係と思って良いですよね?
449 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 18:49:17.01 ID:zi1IwKwq.net] ゲェーッ -O3 はダメだけど -fast は期待通りに動きました あまりにも意味不明なのでこれに手を出すのはやめておきます 失礼しました
450 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 18:57:42.79 ID:CGp4yDz+.net] やべー未定義動作踏んでそう
451 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 19:09:16.56 ID:akuykRB/.net] あるよなぁ。 FortifyやCodeSonarといった静的解析ツールで検出できたらいいが、どこまでできるんだろう。
452 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 23:58:43.73 ID:iNrFbyNf.net] 複素数とか高々数値メンバが2つとかそれぐらいの話なのに なんでビットコピーできないと発狂するのかイミフ
453 名前:デフォルトの名無しさん mailto:sage [2021/06/20(日) 23:59:56.38 ID:iNrFbyNf.net] 備え付けの手段で実数部と虚数部毎に代入するとか 構築とかしたらええんじゃ
454 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 01:37:57.43 ID:czIvoWKn.net] >>437 >>436 によるとサイズも並びも一致することを規格が暗に示してるようなんだ。1つ目の回答を見てくれ
455 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 01:48:21.79 ID:0g7/88j3.net] まだ「暗に」とか言ってんのこのキチガイ コイツのせいで不必要に大事になった感はあるよね
456 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 01:52:02.85 ID:Im5VqdJw.net] >>446 お前のコードで誰にも迷惑かからないなら、もう規格云々はいいから自分の思い込みたいように好きにやれば良いよ
457 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 09:03:02.99 ID:G6bnr+rx.net] T* をとるオーバーロードコンストラクタに const T* x を渡したら、argument do not much だからとエラーになりました。 が、(T*)x を渡したらOKでした。 (T*)をつけてようがつけてなかろうが、x というポインタの const 性は変わりませんよね? (つまり x を変える挙動があったらプログラムは終了しますよね?) なぜ引数の型のマッチには (T*) が必要なのでしょうか。 できればキャストしたくないので、こうすれば避けれるとかこう思えば安全というのがあったら教えていただきたいです
458 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 09:16:37.40 ID:yA/sh2j8.net] >>449 const性変わるんじゃない? const T* xなんだから xはの先にある*xは変えてはいけないという指示をコードかいた人は出していて そのT*をとるコンストラクタはその中で変更する可能性を言ってるんだから T*にキャストして渡したらコンストラクタの中で変更され可能性が出るよ
459 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 09:20:07.55 ID:yA/sh2j8.net] >>449 ああ、だから>なぜ引数の型のマッチには (T*) が必要なのでしょうか。 というと 本来ならconst指定されてて変更してはいけない変数を、変更するけどいいのね?というコンパイラからの確認的なもの
460 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 09:34:04.75 ID:G6bnr+rx.net] >>450 > const性変わるんじゃない? ありがとうございます。 誤解してました。 (というか、そこ変えれるなら何でもありな気が……) >>451 実は、他人の作ったライブラリとの橋渡しでこういう問題が出ました。 知る限りではそのライブラリは引数のポインタの指してる先を変えないのですが、どうやらキャストはするしかないようですね。 この件で (T*) とは別に const_cast<T*> なるやり方の存在も知って、Cスタイルのキャストよりはこちらの方が良いという説明がいろんなところでされてるのですが、正直全く同じものに見えます。 なぜ const_cast の方がマシなのでしょうか?
461 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 09:36:14.94 ID:yU7HyP9W.net] うん、マシだね 特にその問題では
462 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 09:49:17.82 ID:yA/sh2j8.net] >>452 Cスタイルキャストは状況に応じてよしなにキャストしてくれるんだが これがたまに意図しないキャストになる場合があるから、意味を明確にするためにC++のなんちゃらキャストをする よほどのことがないと変なキャストにはならないとは思うけど一応
463 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 09:58:36.45 ID:yU7HyP9W.net] const_castはint*→char*のように指す先の型は変更できない だから、そのような変更をしようとしたらエラーになるし そのような変更を意図していないことも示せる
464 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 10:07:37.10 ID:5d1ivHhj.net] >>452 誤解してるようだけど、constってのは基本的にはバグ抑止のためのもので 文法上のルールに過ぎないのよ 実行時にチェックが走ったりするわけではない で、意図的に破ることも一応出来る。意図的に破るときはそれが見てわかるようにconst_cast使おうね、 Cスタイルのキャストは何でも通しちゃうから避けようねってだけ
465 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 10:07:43.43 ID:G6bnr+rx.net] >>454-455 なるほど。ありがとうございます 今は const_cast で渡すことにします
466 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 11:07:11.82 ID:JzAz8iJE.net] >>441 この件諦めきれなくて少し調べてみたら、 -O3 はダメだが -O3 -static -ipo は正常に動く ことが分かった 更に、icpcでなくg++なら最適化レベルによらず正常に動くことが分かった この場合陥っていがちな失敗なんてないですかね ググってもなかなか体系的な知識に出会えなくて、、、
467 名前:デフォルトの名無しさん [2021/06/21(月) 15:28:43.32 ID:os4CEfZ3.net] 諦め切れないくらい気になるなら -S で .asm コード見るべき
468 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 15:39:13.82 ID:s5hePRzy.net] こんなところでC++が中途半端に出来るだけが自慢の専門卒みたいな連中に尋ねるよりも 大学の先生かチューターの院生に尋ねた方がいいだろう 進みたい研究室があればそこに行って訊くと良い
469 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 16:20:08.51 ID:mdGWC+9J.net] >>458 たぶん初期化漏れとかの未定義動作 -Wallでコンパイルすれば何かわかるんじゃね
470 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 16:27:39.69 ID:JzAz8iJE.net] >>459-461 すんませんあざす asmコードとか未知の領域ですけど勉強になりそうですね -Wallは一応常につけてて、ワーニング全部潰すようにはしてます 全部のオブジェクトにvolatile付けたり外したりしてみようかな
471 名前:デフォルトの名無しさん [2021/06/21(月) 17:09:40.79 ID:os4CEfZ3.net] 適当に弄って適当に動いたように観えて 適当に解決したって言い張るやつは成長しない
472 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 17:40:48.54 ID:uOMSqfSW.net] 短かったり切り出せるようなコードだったらcompiler explorerとかもあるよ
473 名前:はちみつ餃子 mailto:sage [2021/06/21(月) 17:44:51.49 ID:5bV+3LP7.net] const ではないオブジェクトについて const 付きにキャストしている場合には const を剥がしてから書き込みをすることは OK だが、 元々 const なオブジェクトから const を剥がして書き込むのは未定義で、 実際に最適化で壊れることはある。 ちなみに const なオブジェクトから const を剥がしても読むのみなら OK。 LLVM 9.0 で const 領域への書き込みを最適化で削除するする方針になってる。 https://releases.llvm.org/9.0.0/docs/ReleaseNotes.html#noteworthy-optimizations
474 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 20:26:42.47 ID:yU7HyP9W.net] >>460 院生ねえ。。。修士の新人は手放しできないんだけどな レッテルで色眼鏡つかう奴って 情報処理特種とかでもひれ伏すのか? 学生みたいなコード書くアホ知ってるけどw
475 名前:デフォルトの名無しさん mailto:sage [2021/06/21(月) 23:06:59.47 ID:0VSE6TcG.net] インテルコンパイラ様ともなれば プラグマで関数単位で最適化レベルを変えられるんじゃないの 動くパティーンが分かっているのなら二分探索で問題の箇所を見つけるこ とができうる
476 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 00:52:42.42 ID:JdLoAtTW.net] C++の参照で渡した構造体を 中で別の構造体に実態コピーしたい時ってどうしたらいいんでしょう void CTest::SetData(Kouzoutai &kozo) { if(kozo.judge == 1){ _KozoTmp = kozo; }else{ //色々する } } とすると、_KozoTmpってkozoと同じアドレスになっちゃって、 _KozoTmp.judge = 10とかしちゃうともとのkozo.judgeも変わっちゃいますよね ポインタだったら _KozoTmp = *kozo; とかやればいいんでしょうけど 参照で渡した時ってどう書けばいいんでしょう
477 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 01:00:09.80 ID:cH2Us/Cy.net] それで普通にコピーされるだろ なんでされないと思うの?
478 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 01:05:17.48 ID:JdLoAtTW.net] 参照にした時って、ポインタみたいにアドレスコピーにならないの?
479 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 01:15:12.93 ID:cH2Us/Cy.net] あのさ、_KozoTmpは何だ?Kouzoutai型だろ?Kouzoutai*でもKouzoutai&でもないだろ? なんでアドレスなんか持てると思うの?
480 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 01:21:47.48 ID:JdLoAtTW.net] あ、そうなんだ ありがとうございます kozoを参照で渡したから _KotoTmpも無理矢理アドレスになるかと思ってました
481 名前:はちみつ餃子 mailto:sage [2021/06/22(火) 01:22:19.02 ID:Ikkk/uWu.net] >>468 参照というのはいうなれば別名。 SetData の実引数と kozo は「同じもの」と考えて構わない。 (少なくともその場合は)
482 名前:デフォルトの名無しさん [2021/06/22(火) 10:52:00.08 ID:2AbGnqy7.net] copy コンストラクタ と move コンストラクタ ってみんなちゃんと書いてる? デフォにまかせてる?
483 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 11:08:19.79 ID:jiZrgPwV.net] ものによる ポインタやハンドルがあれば書いたり=delete;したり 実体だけなら大抵デフォ
484 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 11:38:53.75 ID:PhquAAua.net] =defaultが多い
485 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 11:45:11.84 ID:hpNVAZMN.net] コピーコンストラクタがあったらムーブ自動生成されないんでしょ?
486 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 13:58:37.72 ID:jiZrgPwV.net] 俺、タイプ量の少なさは美しさの1つだと思ってるから =default;は本当に必要なときだけ書く
487 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 14:51:15.52 ID:4bX8g7Cj.net] doxygenでドキュメント作成してるけどソースが見づらくてコメント無い方がいいのではと思ってしまう
488 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 15:03:38.14 ID:zJk9T2bQ.net] >>479 関数ヘッダーだけでええんちゃうん?
489 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 16:50:07.47 ID:T8maLWCY.net] >>480 テンプレート系のライブラリなので
490 名前: mailto:sage [2021/06/22(火) 19:42:13.49 ID:9FGytWqi.net] もう C は C89 で止めれ C++ は C89 だけ受け付け可能であれば、あとは好きに変えてもらってもかまわない
491 名前: mailto:sage [2021/06/22(火) 19:43:07.45 ID:9FGytWqi.net] >>473 反対せざるを得ない意見です…‥
492 名前: mailto:sage [2021/06/22(火) 19:43:53.44 ID:9FGytWqi.net] >>474 コピコンはちゃんと書きますが、ムーブ?何?それ美味しいの?
493 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 20:42:23.52 ID:InXfs1nZ.net] >>4
494 名前:77 あったら使われる(一時オブジェクトの場合に)ってだけだぞ やること一緒なら書かんでいい、時間の無駄 [] [ここ壊れてます]
495 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 21:50:49.86 ID:7Ks2gqqv.net] >>474 デフォルトで済まない場合だけ明示的に記述するのが普通じゃないかねぇ。 =defaultにするか暗黙定義にするかは好みがあるだろうけど。
496 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 22:22:06.65 ID:4bX8g7Cj.net] >>484 美味しいとき”も”あるよ
497 名前:デフォルトの名無しさん mailto:sage [2021/06/22(火) 22:45:00.81 ID:d6n1ZZoB.net] >>482-484 ロートルはちょっと黙ってて
498 名前:はちみつ餃子 mailto:sage [2021/06/23(水) 04:03:41.13 ID:pZ1DtdbH.net] >>482 C89 ってことは暗黙の関数宣言とかのウンコ機能も含めて言ってるわけ?
499 名前:デフォルトの名無しさん mailto:sage [2021/06/23(水) 04:16:44.74 ID:Vmwdc4hc.net] >>485 最近デカくて古いコンテナのコピーに悩まされてるから、アドレスを託すみたいな形でムーブしたい
500 名前:デフォルトの名無しさん mailto:sage [2021/06/23(水) 06:19:12.12 ID:rIfoeFmJ.net] コピー回避なんていくらでもどうにでもなるのに どんなヘボなんだ
501 名前:デフォルトの名無しさん mailto:sage [2021/06/23(水) 08:31:09.62 ID:nCHirhrB.net] いや、だからそれがアドレスを渡すとか参照で渡すってことでしょ
502 名前: mailto:sage [2021/06/24(木) 20:04:48.26 ID:i6kIKJxB.net] >>488 黙れ、小僧! お前に C++ の苦しみ
503 名前:が分かるのか? [] [ここ壊れてます]
504 名前: mailto:sage [2021/06/24(木) 20:10:35.44 ID:i6kIKJxB.net] >>489 ウンコ機能はC99の方が多い、という認識です
505 名前: mailto:sage [2021/06/24(木) 20:11:16.37 ID:i6kIKJxB.net] >>487 具体的に
506 名前:デフォルトの名無しさん mailto:sage [2021/06/24(木) 21:10:55.26 ID:3QBHDC7A.net] >>495 メモリ確保するようなクラスの場合、メモリ確保の手間省ける。 それ以外でムーブにコピー以上の利点知らない
507 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 00:44:09.12 ID:+R97TjGx.net] んまー(通常の関数呼び出しと違って)コピコンは放っといても勝手に呼び出しが削減される(副作用がある可能性ガン無視で)からな 昔から
508 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 00:55:10.74 ID:+R97TjGx.net] コピコン呼び出し最適化に頼らねばにっちもさっちも行かないシチュエーションは多々あるから 右辺値参照はマジ不完全 例えば Foo operator+(const Foo& lhs, const Foo& rhs) { Foo x(lhs); // 馬鹿正直にやったらコピー1回 x += rhs; // Foo& Foo::operator+=()が定義済みとする return x; // 馬鹿正直にやったらコピーがもう一回 } みたいな、 とこの前思いました ※ 個人の感想です
509 名前: mailto:sage [2021/06/25(金) 01:03:22.61 ID:pWufOIHg.net] >>496 要はクラスC のオブジェクトA の中にポインタがあった場合、オブジェクトA を今後一切つかわない前提でオブジェクトA の持つポインタの値をオブジェクトB にコピーするやりかた、ということですよね 言われるほど凄い機能にも革新的な機能にも思えないので来ているのですが、クラスを返すときには、もしかしたら使えるかもしれませんね でも、すでに RVO があるのでしょう?
510 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 01:11:32.66 ID:xLwe8284.net] >>498 それは左辺値参照だよ。
511 名前:はちみつ餃子 mailto:sage [2021/06/25(金) 01:12:27.64 ID:/YhIejlL.net] >>499 それが出来るということは重要じゃなくて文脈によって勝手に使い分けられるということに意味があるんだよ。
512 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 04:23:14.07 ID:2CfGrUVh.net] move対応してないデカいクラスはマジ迷惑だろ
513 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 06:23:42.07 ID:+QaNJXlp.net] ポインタ、参照、this、スマポ、[&] いくらでもどうにでもなる
514 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 06:38:22.69 ID:byKvXpEn.net] えっ老害??
515 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 06:40:16.50 ID:FhN3idtW.net] >>499 RVOはC++17で保証されたけどNRVOは保証されてない
516 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 07:44:44.86 ID:+QaNJXlp.net] C++03時代を生きてないやつからはそう見えるのか
517 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 08:48:57.50 ID:z3/X9CIt.net] {a, b, c,...} が a, b, c,... という要素からなるリストを表すとき、 {a, {b, {c, d}, e}, f, g, {h, i},...} みたいな構造は a, b, c,... が全部同じ型だとしても tuple としてしか表せませんよね?
518 名前:デフォルトの名無しさん [2021/06/25(金) 10:23:01.70 ID:Wd+wOk9Z.net] json yaml listのtree なんでも
519 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 10:45:58.24 ID:z3/X9CIt.net] >>508 ありがとうございます そうですね。STLとかboostのコンテナに囚われ過ぎてました
520 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 10:52:18.80 ID:tyTj/nU0.net] 老害はC++スレに書き込むなよ 昔の話ばっかだよおじいちゃん
521 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 13:12:18.39 ID:+QaNJXlp.net] 後から入ってきたくせに図々しいやつだな 先住権てやつでこっちが偉いんだよ 気に入らねえんなら他当たるか自分でサーバー立てな
522 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 13:16:46.30 ID:cHfQsTpJ.net] C++03の話なんてもうすんなよ C++11からはもう別言語やんか
523 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 13:27:35.28 ID:+QaNJXlp.net] おまえの主観は関係ない
524 名前:はちみつ餃子 mailto:sage [2021/06/25(金) 13:41:54.77 ID:/YhIejlL.net] >>506 C++03 時代を知ってるからそれが (少なくとも C++11 に比べれば) クソだってこともよく知ってるよ。
525 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 13:43:28.90 ID:ALny3hkX.net] 本気で別言語だと思ってるやつって大抵何も作ってないゴミガキだと思うけどなぁ・・ STL的なアルゴリズムや新要素と親和性が高いのは、基本的に標準ライブラリだけなんだが 最近各種コンストラクタ(ムーブ込み)、代入等だけ長々と書いて「実質ほぼ何もしないクラス」を書いてドヤってるアホとかよく見かける 便利になってるのは確かだけどね・・
526 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 13:45:10.88 ID:ALny3hkX.net] >>514 俺も必要もなく03以前で書きたいとはまず思わんが、クソとか貶すのはやめた方がいいと思うよ
527 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 18:07:04.42 ID:aibvvCTW.net] gets()とか好きそう
528 名前:デフォルトの名無しさん mailto:sage [2021/06/25(金) 18:33:58.19 ID:xqBptTy/.net] (σ・∀・)σゲッツ!!
529 名前:デフォルトの名無しさん mailto:sage [2021/06/26(土) 00:08:46.09 ID:O9GH5wVp.net] ゲッツって初めて聞いた ゲットエスって読んでたんだが
530 名前:デフォルトの名無しさん mailto:sage [2021/06/26(土) 07:06:09.54 ID:MV3qzcHy.net] こことCスレでは古くからあるネッスラだよ
531 名前:デフォルトの名無しさん mailto:sage [2021/06/26(土) 07:21:39.68 ID:+MI3rh96.net] scanf()をスキャンフと呼ぶけどprintf()をプリントエフと呼ぶ感じ
532 名前:デフォルトの名無しさん mailto:sage [2021/06/26(土) 08:05:40.57 ID:vR4ZYNRj.net] プリンテフ
533 名前:デフォルトの名無しさん mailto:sage [2021/06/26(土) 08:08:29.30 ID:EcYCTODA.net] ifndef イフンデフ
534 名前:デフォルトの名無しさん mailto:sage [2021/06/26(土) 11:51:24.28 ID:7nyRjnb4.net] アとイ
535 名前:デフォルトの名無しさん mailto:sage [2021/06/26(土) 13:16:45.08 ID:l0P5IISj.net] C++20でもバイナリファイルからdoubleとかの値を読み出す時って未だにreinterpret_cast使う感じ?
536 名前:デフォルトの名無しさん [2021/06/26(土) 16:37:39.40 ID:qjgQHw2b.net] HTML★ふとまる
537 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 10:16:13.68 ID:0fbyaJPK.net] basic_istream::readの引数がvoid*なら何も悩まずに済むのにな
538 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 11:20:36.11 ID:hddKqCef.net] ファイルに書いている時点でアラインメントの保証が難しいから結局memcpyになる気がする
539 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 12:53:25.35 ID:CJK40NDs.net] アライメントの問題はファイル関係なくね↑?
540 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 13:14:05.28 ID:CJK40NDs.net] エンディアン変換が関係しない場合 C++20でもバイナリファイルからdoubleとかの値を読み出す時はfread() 書き込むときはfwrite() 何の問題も無いし速い……
541 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 13:16:25.37 ID:CJK40NDs.net] ていうかエンディアン変換が関係する場合でも fread()してからメモリ上でエンディアン変換しても良いし メモリ上でエンディアン変換してからfwrite()したら良い 特にファイル内容全体がメモリ上に収まるケースとかは上記だけでほとんど何も考えなくてもよい
542 名前:デフォルトの名無しさん [2021/06/27(日) 13:48:27.15 ID:NNV++T6E.net] P言語、Ruby、Java、C#などでファイルを読んだり書いたりしなければならなくなることを想定したファイル仕様にしたほうがいいと思うけどどうかな
543 名前:はちみつ餃子 mailto:sage [2021/06/27(日) 13:55:06.53 ID:+5rTVQj/.net] スタンダードレイアウトな型はバイナリレベルでコピーしてかまわないし 結果的に fwrite して fread できることは保証されるが、 具体的なレイアウトについての保証はない (他の処理系では同じレイアウトにならないかもしれない) ということも合わせて考えると適当なシリアライザは挟んだほうが良いな。 多言語を意識しつつ高速なバイナリフォーマットというと MessagePack あたりかな?
544 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 13:57:17.27 ID:mY5L/v8k.net] PerlやPythonでバイナリ読み書きするのに何の支障もないだろ。
545 名前:はちみつ餃子 mailto:sage [2021/06/27(日) 14:00:08.24 ID:+5rTVQj/.net] >>534 読み書きに支障はないが、言語上の型とバイナリの対応付けについて明確な保証がないと困る。
546 名前:デフォルトの名無しさん [2021/06/27(日) 14:16:00.40 ID:U1pSP8r9.net] バイナリなんだからどう扱おうが自由だろ 言語のせいにするのは本人の技術が無いから 言い訳するな
547 名前: mailto:sage [2021/06/27(日) 14:25:54.48 ID:I46qTe+f.net] 今時数値をバイナリで読み書きするとか、あり得ないのでは?
548 名前:デフォルトの名無しさん [2021/06/27(日) 14:30:38.43 ID:NNV++T6E.net] Comparison of data-serialization formats - Wikipedia https://en.wikipedia.org/wiki/Comparison_of_data-serialization_formats
549 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 15:19:43.80 ID:o9peEwic.net] >>537 バイナリでないと実用的でないデータなんていくらでもあるし。画像、動画、アーカイブ、db、ip... qzはもうエロ画像見るなよ。
550 名前: mailto:sage [2021/06/27(日) 15:44:56.12 ID:I46qTe+f.net] >>539 ごめんなさい誤りましたので謝りますからその刑だけは平にご容赦を‥‥
551 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 15:47:12.10 ID:mY5L/v8k.net] >>535 保証されてるから支障はない。エンディアンが違うデータだって読み書きできる。
552 名前:はちみつ餃子 mailto:sage [2021/06/27(日) 15:54:09.98 ID:+5rTVQj/.net] >>541 データがリトルエンディアンなのかビッグエンディアンなのかわかっていればね。 C++ が単にメモリ上のデータを書き出したときに、それがどっちなのか、 (言語としては) 保証してないって話をしてるんだよ。
553 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 16:14:20.16 ID:jKhjPg/S.net] C++20でstd::endianが使えるようになるけど
554 名前: mailto:sage [2021/06/27(日) 16:39:33.97 ID:I46qTe+f.net] シェアの高かった 68 系かインテルザイログ系か、の二分図がここにも残っているのですか もう UTF-8 のようなエンディアンに依存しないバイナリが優秀だ、という価値観にするべきかと
555 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 17:01:10.06 ID:CxF0bT8t.net] インターネットのプロトコルはビックエンディアン USB等のPC系発祥のデバイスはリトルエンディアン この辺はもう変更しようが無いだろ
556 名前:はちみつ餃子 mailto:sage [2021/06/27(日) 18:13:48.48 ID:+5rTVQj/.net] >>544 ここでのトピックは >>530 に対しての反論。 メモリ上にあるバイト列には保証がないからなんらかの明確な データ交換用フォーマットに変換する処理が必要という話で、 出力先のデータ交換用フォーマットが BE か LE かなんていう以前の段階。
557 名前:はちみつ餃子 mailto:sage [2021/06/27(日) 18:17:55.59 ID:+5rTVQj/.net] ファイルに書き出すにあたって「エンディアンの変換が不要なら」という前提を置きたくねぇなぁという話だな。 パディングとかも入るかもわからんし。
558 名前: mailto:sage [2021/06/27(日) 19:47:44.56 ID:igNiq52h.net] >>546 であれば、私はどちらかというと >>530 の味方側ですね、>>530 がそう意図しているかどうかは不明ですが、処理系のエンディアンを仮定することなくコードを書くことは可能だったと記憶しています。‥‥@ ただ同時に、確かにパフォーマンスの点で過剰な不利を承知で >>537 を再提示するべきかな つまり、>>537 みたいな画像フォーマットはありました PPM/PGM/PBM https://mevius.5ch.net/test/read.cgi/tech/1434079972/73 このコードは@を検証したものだったかと遠い記憶に残っていますね あ、罰ゲームは勘弁ね、私だってエロ画像は見たい‥‥https://www.youtube.com/watch?v=TvDWJif1sSI
559 名前:はちみつ餃子 mailto:sage [2021/06/27(日) 20:29:20.98 ID:+5rTVQj/.net] >>548 だからそういうコードが書けるかどうかという話じゃなくて 書かなきゃなんない (書くべき) ねという話なんだってば。
560 名前: mailto:sage [2021/06/27(日) 20:58:56.14 ID:2wFMzLzL.net] >>549 それは失礼しました
561 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 22:44:17.18 ID:mY5L/v8k.net] >>542 C++だって読もうとするバイナリデータのエンディアンを事前に知らなきゃならんのは変わらんだろ。 自分で書いたものを読むならエンディアンが一致するのはあたりまえ。
562 名前:はちみつ餃子 mailto:sage [2021/06/27(日) 23:46:30.32 ID:+5rTVQj/.net] >>551 > エンディアンを事前に知らなきゃならんのは 知らなきゃならないがわからん (保証されてない) のだという話をしている。 C++ で書いてメモリをそのまま書き出したらそれのエンディアンは保証されてない。 言語が何であれデータフォーマットが固定されてないとどうにもならん。
563 名前:デフォルトの名無しさん mailto:sage [2021/06/27(日) 23:53:27.71 ID:mY5L/v8k.net] >>552 それは言語関係ない話だろ。
564 名前:はちみつ餃子 mailto:sage [2021/06/28(月) 00:31:47.85 ID:nxXyAxnK.net] >>553 言語に関係あるという話はしてないよ。
565 名前:デフォルトの名無しさん [2021/06/28(月) 00:34:04.32 ID:AdoNh79c.net] Javaはメモリモデルも明確に決まってたんじゃないかな
566 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 02:47:25.75 ID:DsF+RsPk.net] 多言語間でポータブルにしたくば XMLとかyamlとかjsonにしたら良いんじゃーあ!
567 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 03:12:57.95 ID:DsF+RsPk.net] どうしてもバイナリファイルが良いという向きは、 パディングとかもfwrite()とfread()で取り扱い得る といっても単に適当なサイズのバイトの配列として読み書きして メモリ上でご使用のアーキテクチャーに合わせることになるが fwrite()とfread()を使わなければもっとマシになるという類の話ではない
568 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 03:44:20.73 ID:QdlxBFRk.net] 別にバイナリ吐き出すときは必ずポータブルにする必要ないだろうに なんで勝手に条件追加して批判してんだか
569 名前: mailto:sage [2021/06/28(月) 07:17:27.29 ID:oYDZ1nWa.net] >>556 お手軽な XML/yaml/json 読み書きライブラリを紹介してください、よろしくお願いいたします
570 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 07:48:39.66 ID:cZa6zFVz.net] >>554 PerlでもPythonでもC++と変わりなくバイナリの読み書きはできるという話をしてるんだが。 エンディアンがわからなければC++でも読めないというのは当たり前。 フォーマットを知らないバイナリファイルってことだからな。
571 名前:デフォルトの名無しさん [2021/06/28(月) 08:30:45.47 ID:RYml5aTx.net] これ以上、バイナリ読み書きの話をする前にとりあえず>>538 に目を通せ 車輪の再発明をしたいのか、既存の車輪を利用したいのかをはっきりさせてから話を進めたほうがいい
572 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 09:09:23.58 ID:XSoi24Ug.net] 僕はノンバイナリーだから読みたくないです
573 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 09:56:34.91 ID:SQEqm/bz.net] こんどはバイナリに噛み付いてるキチガイがいるな
574 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 11:09:48.91 ID:bLKGwGq9.net] 標準ライブラリのみであれば車輪の再発明しか手段がない?
575 名前:デフォルトの名無しさん [2021/06/28(月) 12:52:58.19 ID:bIZ7S0Sd.net] MsgPack は json と同じで無駄が多い
576 名前:デフォルトの名無しさん [2021/06/28(月) 12:59:22.39 ID:bIZ7S0Sd.net] >>558 温暖化詐欺SDG詐欺と手口が一緒だな
577 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 13:35:34.04 ID:quG4wdoj.net] >>559 WSL2, Ubuntu 18.04 では、 apt list --installed libxml2 libxml2/bionic-updates,bionic-security,bionic-updates,bionic-security, now 2.9.4+dfsg1-6.1ubuntu1.4 amd64 [インストール済み、自動]
578 名前:デフォルトの名無しさん [2021/06/28(月) 13:52:30.89 ID:5OdlGlMi.net] Comparisonて何て読むの? コンパリソン?
579 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 14:55:11.19 ID:qFu4iqR6.net] msgpackはクソやね バイナリの扱いに慣れないスクリプト坊がバイナリを扱わざるを得なくなった場合を除いては全く価値のないフォーマット
580 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 14:56:29.69 ID:R7ScYjSP.net] >>568 こんpぇぁりzん https://www.google.com/search?q=comparison
581 名前:デフォルトの名無しさん [2021/06/28(月) 15:26:12.03 ID:JcAv6JCW.net] >バイナリの扱いに慣れないスクリプト坊がバイナリを扱わざるを得なくなった場合 この表現すき💛
582 名前:デフォルトの名無しさん [2021/06/28(月) 15:26:13.01 ID:JcAv6JCW.net] >バイナリの扱いに慣れないスクリプト坊がバイナリを扱わざるを得なくなった場合 この表現すき💛
583 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 16:13:11.20 ID:dKXkMhte.net] >>569 のお勧めは何? 理由もセットで教えて頂戴。
584 名前:デフォルトの名無しさん mailto:sage [2021/06/28(月) 16:32:50.30 ID:uBCftstC.net] 「モジュール」はC++で作られたパッケージを配布しやすくしますか?
585 名前:はちみつ餃子 mailto:sage [2021/06/29(火) 00:03:30.47 ID:OP5z1lEO.net] >>560 そうだよ。 その当たり前の話をしてるんだよ……。 互換性の問題というのは内部的なものなら問題が起きたときに修正すればいいが、 外部に出ているデータはそれに皆が合わせなければならない仕様と化すので 特定の C++ 処理系 (実行環境) でなら処理できるけど 出力されたデータフォーマットの詳細はわからんし処理系のバージョンがちょっと変わったら変わるかもしれん というのでは困るやんというごく普通の話。 (もちろん普通の処理系はちょっとバージョンが更新されたくらいでは バイナリ互換性をあまり壊さないように配慮するのが普通ではあるけど。)
586 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 00:15:58.47 ID:MxyOwUyS.net] >>575 いつのまにか話ずらしてんな。 >>535 >読み書きに支障はないが、言語上の型とバイナリの対応付けについて明確な保証がないと困る。 言語上の型とバイナリの対応付けはPerlでもPythonでも保証されてるんだよ。
587 名前:はちみつ餃子 mailto:sage [2021/06/29(火) 00:20:30.40 ID:OP5z1lEO.net] >>576 されないよ。 ファイルのバイナリが BE か LE かわかっていない状況の話なんだから。
588 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 08:12:22.23 ID:MxyOwUyS.net] >BE か LE かわかっていない状況 これの意味だが ・全く何の情報もない状況 →どんな言語を使おうが正しく読める保証がないし論ずるだけ無駄。 ・>>552 の「C++ で書いてメモリをそのまま書き出したらそれのエンディアンは保証されてない。」状況 →「自環境のエンディアン」で読めるのはC++でもPerlでもPythonでも同じ。
589 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 08:29:00.28 ID:qbDSHPwG.net] >>573 方法はともかく、普通にビット列かバイト列のレベルで仕様を決めてその通りに読み書きすりゃいいんじゃない C++プログラマなら生データの扱いは得意でしょ とはいえ手間がかかるしミスを生じやすいのも事実なので、めんどくせえ今すぐ読み書きしたいってだけならprotobufとかavroとか他にも色々あるよ msgpackとの大きな違いはスキーマの有無で、スクリプト言語じゃなきゃスキーマはあったほうが便利だし、一般に実装が高速になりやすくデータサイズも小さくできる
590 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 08:38:20.49 ID:zFDqDEto.net] >>579 「他人含めた仕様の強要」という観点が抜けてない? それに、何回車輪の再開発させるつもりだよ。
591 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 08:57:28.61 ID:bpKPj1F0.net] >>580 強要したいならちゃんと仕様書書いて押し付けるだけの話 実装が面倒ってんならそれこそprotobufのようなスキーマのある汎用フォーマットならスキーマさえ書いとけば大抵の言語でserde用の型の自動生成までやってくれるよ その点で言えばmsgpackは所詮mapなんで、仕様を強要したいなら別途仕様書が必要になるよ
592 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 10:54:24.87 ID:c9Dh6S0q.net] 実の無い話はすぐ切り上げるのが大事だぞ お互いの時間を無駄にしあってはいけない
593 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 12:00:43.57 ID:gO51uzZW.net] 他人に構ってもらわなければ生きて行けないかまってちゃん人種は救いようがない
594 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 13:20:29.38 ID:IWxlvq96.net] >>560 Perlでバイナリを扱うのは物凄く大変だった。 さまざまな自動変換がかかってしまうので、結局どうなるのかが分からない事が 多かったから。 例えば、数値なのか、文字なのかの区別が曖昧な感じで、たままた数値が入った 文字が、勝手に数値になって、'0' + 1 が、0x30 + 1 のつもりが、0 + 1に なってしまったり、物凄く難しかった。 ASCIIコードの数値番号を取得したいと思っても、結果が数値の入った文字列に なったりとか、よく分からない事が多かった。 何を何に変換しているのか、めちゃくちゃ難しかった。 それがRubyになって、素直な感じになった。
595 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 13:23:14.00 ID:IWxlvq96.net] >>584 16進数も複雑だった。 単に表示したいために16進数の文字列に直したら、どこかで勝手に数値として 解釈されていつの間にか思いもよらぬ「もの」に変化したりとか。 それで、バイナリや文字を細かく扱い際には、如何にCが楽であるかを思い知った。
596 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 14:44:15.68 ID:UyxOx+sC.net] Cというか、それは最早動的型付けか静的型付けかとかの話では
597 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 15:11:46.24 ID:IWxlvq96.net] >>586 JSやRubyは、動的型付けだけど、Perlのように文字と数値の相互変換が勝手に 起きたりはしない。
598 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 15:25:41.01 ID:MxyOwUyS.net] pack/unpack使えばそんな変なことにはならんぞ。 perlでバイナリ扱うなら常識。
599 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 15:37:31.39 ID:IWxlvq96.net] >>588 それ自体はそうでも、その後いろいろなことが起きてややこしかったな。
600 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 18:21:23.30 ID:7i3kfcoq.net] 強気なこと書き込む人はだいたい経験浅い
601 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 18:35:19.68 ID:tM55IFN7.net] ボカァもうOOPは捨てた!w
602 名前: mailto:sage [2021/06/29(火) 18:54:36.80 ID:qfvhyFdx.net] >>578 あなたはちょっと残念な人ですね 実際には C/C++ ならば、処理系が LE/BE どちらに依存かにもかかわらず処理系に独立して LE なら LE用, BE なら BE用に書きわけることができる‥‥@ @の証拠は >>548 ことほど左様に、処理系に独立して LE/BE を書き分けることができるのなら「〜するべき」とかいう「べき論」は無意味でしょう 多分、はちみつ氏は@を失念していたのでしょう、べき論なんて振り回しても無駄なのに、あいかわらずべき論に拘泥するところなどは「ダメリカ様が守ってくださる!」的な馬鹿左翼並の振る舞いですから、そろそろあきらめるべきでしょうね
603 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 21:05:01.01 ID:MxyOwUyS.net] >>592 ? なにか別の話とごっちゃにしてないか?べき論って??? >実際には C/C++ ならば、処理系が LE/BE どちらに依存かにもかかわらず処理系に独立して LE なら LE用, BE なら BE用に書きわけることができる‥‥@ C/C++じゃなくてもPerlやPythonだってLE/BE書き分けられる手段は用意されているって話をしていただけなんだがな。
604 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 21:08:28.05 ID:MxyOwUyS.net] >>589 pack/unpackの後の話ならバイナリファイルとか関係なくて、ようは「Perlがややこしかった」というだけだろ。 >例えば、数値なのか、文字なのかの区別が曖昧な感じで、たままた数値が入った >文字が、勝手に数値になって、'0' + 1 が、0x30 + 1 のつもりが、0 + 1に >なってしまったり、物凄く難しかった。 これなんかまさにそうだな。
605 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 23:39:33.94 ID:uMLxaJ5z.net] この話のゴールどこ?
606 名前:デフォルトの名無しさん mailto:sage [2021/06/29(火) 23:59:54.04 ID:yAVMK7JX.net] pack/unpack使え
607 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 00:03:10.10 ID:6riO4yVW.net] use strict use warnings;; use Carp; use utf8; #use Encode; # ウィンドーズのパスを使う場合必須 our $os_enc = 'cp932'; binmode STDIN, ":encoding($os_enc)"; binmode STDOUT, "encoding(%os_enc)"; でエラーかどうかは (エラー出ない条件) or croak "*** ERR ***"; # 改行は付けない にしてpack/unpackを使ったら何も起きない
608 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 00:07:43.06 ID:d2kdzRUr.net] Encodeは日本語入りのパスとか$ARGV[]とかをutf8にしたり戻したりするのに使う コマンドプロンプトの文字をutf8にしたら実はEncode要らんかもしれんがそこまでは知らん
609 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 00:40:50.04 ID:uW/S3RKL.net] Perlの特定の某なんか出されても知らんがな……
610 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 03:10:15.08 ID:vkj6zKzF.net] Perl Python PHP Java C# EcmaScript TypeScript Javaくらいは流石に教養だろうさ。
611 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 07:38:15.64 ID:F9CAzHJ+.net] func の返り値を変数 hoge に受けるときって auto hoge = func(); auto& hoge = func(); auto&& hoge = func(); のいずれにおいてもオブジェクトの再構築 (コピー) は行われないって思って良いんですよね?
612 名前:デフォルトの名無しさん [2021/06/30(水) 10:58:31.75 ID:x9tVpfG6.net] no
613 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 11:13:43.85 ID:EDSlPJC8.net] >>601 c++17:値のコピー省略を保証、て奴かね。 戻り値が右辺値かどうかで変わるんじゃない?
614 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 12:11:32.93 ID:2LaR0NZ5.net] 関数の戻り値は必ず右辺値のはずだが。
615 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 12:19:35.40 ID:8KWEqHlz.net] んなこたーない
616 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 12:29:48.99 ID:sL9lkuh+.net] 参照返し……と思ったけど、 参照て右辺値だっけ?左辺値だっけ?
617 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 13:29:54.24 ID:2LaR0NZ5.net] 関数の戻り値は、戻り値の型が左辺値参照で有る場合だけは左辺値で、 それ以外は右辺値らしい。
618 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 13:34:03.56 ID:2LaR0NZ5.net] >>606 戻り値の型が右辺値参照の場合、関数呼び出しの結果は、xvalueだが、分類上は、右辺値でもあり、glvalueでもある。 戻り値の型が左辺値参照の場合、関数呼び出しの結果は、左辺値。 戻り値の型が参照型でない場合、関数呼び出しの結果は、prvalueで、右辺値。 prvalue = 純粋右辺値。 glvalue = 一般化左辺値。 xvalue = 消えかかっている値。謎の値とも言われる。
619 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 13:39:20.73 ID:2LaR0NZ5.net] >>601 一番上の書き方だと、少なくとも move になる。 下の二つは、moveもcopyも行われないで、アドレスだけが参照型変数に 入るのだと思う。
620 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 14:18:47.26 ID:DhAhW4Ik.net] >>609 funcの戻り値型が左辺値参照の場合moveにはならんのでは?
621 名前:デフォルトの名無しさん mailto:sage [2021/06/30(水) 14:56:49.27 ID:2LaR0NZ5.net] >>610 その通りで、コピーコンストラクタが呼び出される気がする。 「少なくとも」と書いたのは、効率面で最低でも move が生じる という意味で書いたつもりだった。
622 名前:デフォルトの名無しさん [2021/07/03(土) 19:40:59.20 ID:Ju/axMXt.net] くっそ素朴な疑問だけど 「operator>>」 って声に出して読むときどうしてる? 独学/個人開発なので他の人から聞く機会がない
623 名前:デフォルトの名無しさん mailto:sage [2021/07/03(土) 19:42:38.50 ID:dunp4iC4.net] 右シフト記号?
624 名前:デフォルトの名無しさん mailto:sage [2021/07/03(土) 20:04:04.63 ID:ApVtA7Dx.net] 入力オーバーライドとか? うーん・・・ダブルGT!
625 名前:デフォルトの名無しさん mailto:sage [2021/07/03(土) 20:04:56.30 ID:Y97o1UBK.net] 個人的には「おぺれーたーだいなりだいなり」だな 他人には言ったことないけど
626 名前:デフォルトの名無しさん [2021/07/03(土) 20:18:12.60 ID:Ju/axMXt.net] 自分のレス読んで気づいたけど他の人に声出し読むう機会も無いからどうでもいいな
627 名前:デフォルトの名無しさん mailto:sage [2021/07/03(土) 20:23:06.99 ID:A2f3M294.net] おぺれーたーぐれぐれ
628 名前:デフォルトの名無しさん [2021/07/03(土) 21:03:34.16 ID:WO4lFPcp.net] オペレータ・イン <<は当然オペレータ・アウト
629 名前:デフォルトの名無しさん [2021/07/03(土) 21:05:23.40 ID:WO4lFPcp.net] 朗読問題は根深くて、古くは漢文の読み下しからあり、 座右の書たるC言語を256倍使うための本にもちゃんと発音方法が載ってる
630 名前:デフォルトの名無しさん mailto:sage [2021/07/03(土) 21:29:09.42 ID:iUoBj2xP.net] >> みぎみぎ << ひだりひだり
631 名前:デフォルトの名無しさん mailto:sage [2021/07/03(
] [ここ壊れてます]
632 名前:土) 21:41:24.77 ID:iArH0hMS.net mailto: >>603-611 ありがとうございます func の返り値が左辺値参照である場合を除けば、コピーは起こらないでFAですね で、func の返り値は左辺値参照でない限りは右辺値だとすると、auto& じゃ受けれないから auto&& で受けるべきということですね [] [ここ壊れてます]
633 名前:デフォルトの名無しさん mailto:sage [2021/07/03(土) 22:59:31.74 ID:5pcVeoYl.net] オペレーター、クィっ、クィっ
634 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 03:21:06.85 ID:WJcubPcO.net] auto hoge = func() は場合によってはコピーが起きる という印象、 なぜなら戻り値をスタックのどこに積むかをfunc()の側で指定できないから hogeの実体ドンピシャにfunc()内で構築できる保証が無い コピーが省略され得るのは auto hoge = func(); bar(hoge); みたいな呼び出し元がhogeの用の一時的領域を次の関数呼び出しの引数としてやりくりできる場合だけなんじゃないの
635 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 07:20:46.94 ID:kv3QS/1l.net] ISO/IEC 14882に準じて おぺれーたーらいとしふと
636 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 08:34:51.74 ID:mLloSLib.net] >>623 ??? 最適化されて bar(func()) になるときだけオブジェクトの構築が省略されるって言いたいの? アホか全然レイヤの違う話だよ 右辺値左辺値の概念全く理解しとらんのか (何十年前のプログラマだ) 「印象」でものを語るな
637 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 10:01:09.26 ID:mLloSLib.net] それはそうと、こんなスレでも右辺値と左辺値よくわかってない (概念としてはわかっててもある場合のある値がどっちか判然としない) 人が多いのは、C++のムーブセマンティクスが洗練されてる証拠かもな つまり、プログラマの預かり知らぬところで自動でコピーとムーブが仕分けされているという
638 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 10:11:22.75 ID:dMFRzHLQ.net] >>623 https://wandbox.org/permlink/FOkFiS1EumCHBr0F そんなことないよな? と思いつつやってみた まあ、そんなことないよな ただ実験してて一個だけ気になったのが take_S(S()); ってやった場合、default→moveじゃなくて単にmoveとしか表示されなかった C++11/14でも-fno-elide-constructorsを付けない限りmoveだけ これってなんで?
639 名前:デフォルトの名無しさん [2021/07/04(日) 10:44:02.96 ID:pili1Lz/.net] >>619 万葉集は読み下しですらないからな
640 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 11:45:10.82 ID:WJcubPcO.net] >>627 解説キボティーヌ "copy"と表示されているわけだが
641 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 11:56:43.39 ID:WJcubPcO.net] つかそれを除けば>>623 の通りなんじゃないの >take_S(S()); >ってやった場合、default→moveじゃなくて単にmoveとしか表示されなかった これは呼び出し元がS()の戻り値の実体をtake_S()の引数の実体と合一(スタック上の同一アドレス)にできた例 defaultコンが呼ばれなかったのはstruct Sがメンバを持たないから最適化でデフォルトコンストラが削除された例 通常の関数呼び出しでcoutする処理が削除されたらそればバグだが、 コンストラクタの呼び出し削減の最適化はコンストラクタ内で副作用のある処理を行っている可能性を 無視して行われることが規格のどっかで認められているはず……
642 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 12:12:47.00 ID:WJcubPcO.net] >最適化されて bar(func()) になるときだけオブジェクトの構築が省略されるって言いたいの? 微妙にちげう func()がオブジェクトをコピー返しする関数である以上、その場合だけムーブにする余地があると言って
643 名前:る 実際は auto hoge = func() bar(hoge) (この後hogeを使う人は居ない) と分けて書いたら"move"になりそうなケースなのに"copy"になったらしいが(>>627 のリンク先 >アホか全然レイヤの違う話だよ ムーブにできるのは参照の付け替えとみなせるケースなので上の話(コピーをムーブと読み替え得る条件)が別レイヤの話とは認められない [] [ここ壊れてます]
644 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 12:32:59.30 ID:dMFRzHLQ.net] >>629 表示されたってことは省略されてないよね?
645 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 12:34:44.04 ID:dMFRzHLQ.net] 実験の部分を同時に話題にするべきではなかったな
646 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 12:54:00.52 ID:WJcubPcO.net] >>632 "move"にならずに"copy"になったのは謎だと>>631 に書いてある とわいえ、>>623 の主張を整理すると、 (1) func()が定義上オブジェクトをコピー返しする関数である場合、auto hoge = func() がムーブになるとは限らず、場合によってはコピーが起きる (2) ただし、bar(func()) というケースでは、func()の戻り値をbar()に渡す際に、コピーではなくムーブが選択される余地がある というものであって、bar(func())に類似のケース(>>627 のリンク先)でムーブにならずコピーになったからといって>>623 が否定されたことにはならない (∵ムーブが選択される「余地がある」と言っただけであってムーブにする義務があると言ったわけではない
647 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 13:00:30.08 ID:WJcubPcO.net] ここで「func()が定義上オブジェクトをコピー返しする関数である」のに何でコピーが削除されてムーブに成り得るのか? という疑問を抱く向きもあるかもしれないが、 これについては構造体やオブジェクトをコピー返しするような関数func()が実際には return valueの置き場所にデフォルト構築するだけのコードに落ちることがあるのを見たらワカル
648 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 13:13:36.22 ID:dMFRzHLQ.net] >>634 もしかして、コピーの代わりにムーブでオブジェクトが構築されることを「コピー省略」だと思ってる?だとしたら違うよ ていうか実験の部分は自己解決しました C++17で必須になったっていうだけで、それまでも(C++98ですらも)省略されることが許されるというのは明記されていたんですね
649 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 13:25:14.33 ID:bouvqZmG.net] 「コピー返し」ってなんぞ?
650 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 13:29:00.70 ID:WJcubPcO.net] >>636 >もしかして、コピーの代わりにムーブでオブジェクトが構築されることを「コピー省略」だと思ってる?だとしたら違うよ 別に 言っているのは 1. オブジェクトの構築はfunc()内のどこかしらで行われる 2. 1の方法によっては、func()がreturn valueをreturnする際のコピーは省略される(func()がそういうコードになる 3. func()がスタック上に返したreturn valueを呼び出し元が自動変数hogeのエリアにコピーする代わりにbar()の引数エリアにmoveする ことがある(>>601 が言うように常にmoveになる、というわけではない と言う簡単な主張
651 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 13:49:07.73 ID:dMFRzHLQ.net] >>638 じゃあ結局>>623 のこの部分は間違いってことでいいの? > コピーが省略され得るのは > auto hoge = func(); > bar(hoge); > みたいな呼び出し元がhogeの用の一時的領域を次の関数呼び出しの引数としてやりくりできる場合だけなんじゃないの
652 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 14:05:29.04 ID:bouvqZmG.net] 意味ワカンネ 1. func が内部でオブジェクトを構築する話 2. func の返り値を変数 hoge に束縛する話 3. func の返り値を後で他の関数に渡す話 全部切り分けて考えろよとしか思えんのだが そして 2 について言えば>>621 に尽きるだろとしか思えんのだが
653 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 14:15:48.87 ID:WJcubPcO.net] >>640 いやすまん2は確かに間違いでauto hoge = func()はhogeへのmoveで済む >>639 いやすまん「〜できる場合だけ」という限定は間違いやった ついでに言うとbar(func())でたまたまfunc()がスタック上に作ったreturn valueのアドレスも変えずにそのままbar()に渡せるとき moveが起きるという主張も間違いだったかも……(アドレスも変わらないのなら何の構築も不要
654 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 14:27:18.68 ID:bouvqZmG.net] 何もかもおかしいよお前 「コピー返し」って結局なんやねん 独特の語法でわけのわからんことを主張するな 「印象」「かもしれない」で物事を主張するな 何がわかってて何がわかってないか知れ 質問と主張をごちゃまぜにするな 本格的に社会に居場所なくなるぞ 「全部取り下げます」とだけ言って去れ で一から勉強しろ
655 名前:デフォルトの名無しさん [2021/07/04(日) 14:32:24.17 ID:2p3tbjy0.net] RPGでアイテムを移動させた時に間違ってコピーされてアイテムが増殖する ムーブしないといけない アイテムは一個だけ
656 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 14:37:46.88 ID:HHbHqtlq.net] >>642 面倒見よくて草 昔はこの板にもアンタみたいな厳しい先輩いっぱい居たのにな 今はニワカと趣味グラマが何周送れかわからんポエム呟きあってるだけだし 昔からいる人らは完全スルーしてるはず
657 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 14:52:36.20 ID:WJcubPcO.net] >>642 Callerが(スタック上に)確保したメモリに対してcalleeが構造体を返すという返し方の意味 これについては統一した用語が無いようなのでむしろ知りたいっすね…… >>643 >>623 のコードでSにムーブコンが定義されていなかったら増殖を意図しないケースでも コピコンが呼ばれるのだから>>643 はたとえとしてはイマイチ
658 名前:はちみつ餃子 mailto:sage [2021/07/04(日) 15:12:00.11 ID:7/Zaj2J4.net] >>645 要件を満たすとき (返却値が prvalue のとき) は変数の場所に直接にオブジェクトが構築される.。 コピーやムーブを省略できるというのはそういう意味で、 特に C++17 以降ではコピー省略が許されるときにはコピーコンストラクタもムーブコンストラクタも存在しなくてもいい。 https://wandbox.org/permlink/FOndP8P7Ecv5v5sB
659 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 15:50:43.27 ID:WJcubPcO.net] >>646 のコードをVS2019でビルドしたら >error C2280: 'foo::foo(foo &&)': 削除された関数を参照しようとしています と言われるorz ていうか「prvalueならば必ず変数の場所に直接にオブジェクトが構築される」(例外なくそうなる)のだとしたら これはcallerがcalleeに構築すべき変数のアドレスを渡さねば実現できない芸当だけど ABIにそんな隠れた第n引数を設けることまでC++の規格で決めちゃって委員会、 とそこはかとなく疑問が…… (funcがメンバ変数だった場合、隠れた第1引数でthisを渡すことになっているのにこれにさらに追加?
660 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 15:56:31.25 ID:xLbwwiyt.net] いいからお前はRVOでぐぐって来い 話はそれからだ
661 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 16:02:57.96 ID:WJcubPcO.net] >>648 これか https://blog.kmc.gr.jp/entry/2014/12/20/231430 >まるでメンバ関数における暗黙のthisポインタのように、関数の引数に戻り値を格納する先の変数へのアドレスを渡します。 >そしてそのアドレスの先の上にオブジェクトを構築することで、関数内部での一時オブジェクト >生成を呼び出し元のオブジェクト生成とみなすことができます。 このようにしてRVOは実現されています。 >まるでメンバ関数における暗黙のthisポインタのように、関数の引数に戻り値を格納する先の変数へのアドレスを渡します。 mjk、
662 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 16:18:10.24 ID:2qJME2iB.net] >>649 RVO は、最適化の一種なので、実現方法は色々。 とにかく、コンパイラが、関数の戻り値から左辺へのコピーやムーブを なるべく減らして、いきなりダイレクトに左辺に書き込むような方法を探し出して コード化する。 それをどやってやるかは、関数呼び出しの ABI 依存。
663 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 16:52:18.97 ID:VOtERW9V.net] >>647 エラーになるのは、VS2019のデフォルトがC++14だから。 プロジェクトのプロパティ→構成プロパティ→C/C++→言語 の 「C++言語標準」を「ISO C++17標準(/std:c++17)」に変更すれば通る。
664 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 18:28:13.63 ID:WJcubPcO.net] >>651 確かに「C++言語標準」を「ISO C++17標準(/std:c++17)」に変更したら通った >>651 >(RVOを)どやってやるかは、関数呼び出しの ABI 依存。 そういうものだと今の今まで思っていたが、 C++17で>>646 のコード(コピコンもムーブコンも明示的に削除)がビルドが通るようになるということは、 第2の隠れた引数でcallerがcalleeに構築すべき変数のアドレスを渡すことが C++17では義務化されるとしか解釈できないのでは……
665 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 20:21:13.81 ID:WJcubPcO.net] 第2の隠れた引数でcallerがcalleeに構築すべき変数のアドレスを渡しているのだとすると >>627 のコードが"default"の次に"copy"になるのはある程度説明がつく 1. return_S()関数でS構築 --- ここでS:S()が呼ばれ、"default"表示 2. auto hoge = return_S()では何も起きない(∵1で&hogeにSが構築済み) 3. take_S(hoge)で呼び出しの引数としてhogeをコピー --- &hogeにあるSが、スタックの上の方に引数としてコピーされる結果"copy"表示 しかしhogeはその後使っていないのだから、コンパイラ的には3はmoveになる余地があるはず なお>>641 までの漏れのレスは第2の隠れた引数は仮定せず、return_S()(callee)がスタックのトップに return valueとしてS()を構築して、 それが呼び出し元(caller)が&hogeにcopy(ムーブコンがあればmove)する穏当なモデルを考えていた 実際n3337.pdf(古いが)を読む限りRVOのやり方は全く規定されてないからアリのはず…… 何で>>642 が怒り狂うのかわからん……
666 名前:デフォルトの名無しさん mailto:sage [2021/07/04(日) 22:02:15.33 ID:dMFRzHLQ.net] >>652 別に実装として「隠れた引数」を使えとは規格上決まっていないよ 処理系は適当な専用のグローバル変数を使うようなコードを出力しても構わない >>653 なんで>>642 が怒り狂うのか? >>642 を読んで分からない分からない? あなたの一連のレスはあなた自身以外の誰のためにもなっていないんだよね >>642 でするな、って言われていることは、そういう自分のためにしかならないことでスレを私物化する行為に等しいよってことだ
667 名前:デフォルトの名無しさん mailto:sage [2021/07/05(月) 08:27:16.47 ID:4kBMhQOc.net] >>653 >>603 は調べたんかいな。cpprefjp な。 RVOを含めて調べれば、>>646 だということは分かるだろ。 c++標準の扱いはcpprefjpの参照リンクにもある「値のコピー省略の保証について」が良くまとまっている。 検索・調査能力が低いのは今どきのプログラマーとして致命的欠陥だから、日頃から訓練したほうがいい。
668 名前:デフォルトの名無しさん mailto:sage [2021/07/05(月) 08:31:59.73 ID:4kBMhQOc.net] 補足。 >>653 の2はNRVOだからRVOとは別物な。 NRVOは最適化可能だけどコピー省略は保証されていない。
669 名前:デフォルトの名無しさん mailto:sage [2021/07/05(月) 08:44:01.31 ID:4kBMhQOc.net] >>656 あ、間違えた。NRVOとは関係ないや。 ついでに。 >しかしhogeはその後使っていないのだから、コンパイラ的には3はmoveになる余地があるはず 副作用のあるコピーコンストラクタがあったら最適化はやばいんじゃない? 規格上許されていたっけ?
670 名前:デフォルトの名無しさん mailto:sage [2021/07/05(月) 11:05:56.38 ID:w3Zb0u1p.net] ライフタイムを推論してcopy/moveの振り分けは理論上可能かもしれないが、現行の規格はそんなことは要求しない lvalueからならcopy、rvalueからならmove lvalueからmoveしてほしいならstd::moveしなさい lvalueを渡しているのに勝手にrvalue referenceとして解釈されてぶっ壊されてたまるかよ
671 名前:デフォルトの名無しさん mailto:sage [2021/07/05(月) 12:24:14.81 ID:M+MHtMKE.net] template<class T> class A { public: A()=default; A(T&&); }; この場合、T==Aになるとmoveとcopyを兼ねる?
672 名前:デフォルトの名無しさん mailto:sage [2021/07/05(月) 13:59:53.08 ID:MxHqaq3M.net] C++が出来るとは規格書がちゃんと読めることを言うんだね
673 名前:デフォルトの名無しさん mailto:sage [2021/07/05(月) 15:27:44.85 ID:NDiogwds.net] Macのclang++でコンパイルしています。 cstdlibをインクルードしなくてもrand()が使えてしまうのですが、これはなぜでしょうか?
674 名前:デフォルトの名無しさん mailto:sage [2021/07/05(月) 15:36:50.05 ID:M+MHtMKE.net] 規格票には規格書なんて書いてない 俺はちゃんと読めるんだなんて イキッてるやつはブーメランだな
675 名前:デフォルトの名無しさん mailto:sage [2021/07/06(火) 00:27:03.56 ID:86XKd96p.net] >>657 許されてるよ その状況でコピコンやムーコンが呼ばれるかどうかは未規定(呼んでも呼ばなくてもいい) というかこの「呼ばなくてもいい」っていう規定こそが正に規格がNRVOを認めてる部分そのもの
676 名前:デフォルトの名無しさん mailto:sage [2021/07/06(火) 03:32:03.53 ID:PiE4/OQH.net] 実際、「move さえ省略してほしい」って思惑で auto hoge = func(); と書くところを auto&& hoge = func(); と書いてる人なんているの?
677 名前:デフォルトの名無しさん mailto:sage [2021/07/06(火) 07:29:15.81 ID:6WiwYssU.net] いるよ。
678 名前:デフォルトの名無しさん mailto:sage [2021/07/06(火) 07:45:25.63 ID:FcxtUR1g.net] >>657 エピステーメーも同じようなこと言ってたけどね まぁコピーコンストラクタとかにコピー以外の副作用入れる方が悪い、ってことだろ 実際変な副作用など無いことを前提にしなきゃ出来ない最適化他にもあるやろ
679 名前:デフォルトの名無しさん mailto:sage [2021/07/06(火) 10:03:46.67 ID:t2+Z62DR.net] >>661 stdlib.hにも定義されているが、他のヘッダをincludeすると、 その中から別のヘッダをincludeしている場合も有り、その中からさらに 別のヘッダをincludeしている場合も有る。 また、標準ではstdlib.hやcstdlibで定義されているとされていても、 その他のヘッダで定義されていないとも限らない。
680 名前: mailto:sage [2021/07/06(火) 20:25:19.80 ID:/lKUoH39.net] >>666 >コピーコンストラクタとかにコピー以外の副作用入れる方が悪い 規格票のどこに?
681 名前:デフォルトの名無しさん mailto:sage [2021/07/06(火) 23:17:37.91 ID:2d1Iatqp.net] >>668 規格票持ってるんですか?
682 名前:デフォルトの名無しさん mailto:sage [2021/07/07(水) 00:20:29.64 ID:ACi5C/C8.net] >>668 コイツたまにトリップ外すの忘れて荒らしみたいなことしてんの最高に滑稽
683 名前:はちみつ餃子 mailto:sage [2021/07/07(水) 05:18:00.78 ID:BiM5c4gH.net] >>668 副作用がある場合でも省略されるというのは明記されている。 https://timsong-cpp.github.io/cppwp/n3337/class.copy#31 > even if the copy/move constructor and/or destructor for the object have side effects
684 名前:デフォルトの名無しさん mailto:sage [2021/07/10(土) 14:04:49.30 ID:yQTcABkI.net] >>658 3がmoveになったところで何も壊れるものは無くね? というのと、take_S()に渡される方がぶっ壊されることにはならないので 3がmoveになってもlvalueとして渡されることには変わりは無い
685 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 00:07:46.98 ID:5nx6GB9W.net] >>672 https://cpplover.blogspot.com/2009/11/rvalue-reference_23.html とりあえずこれとか読んでからお願いします 全体的に何が言いたいかよく分からないですがmoveならrvalueとして渡されるのでそこは理解してください
686 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 00:24:04.38 ID:YJk6tGcw.net] >全体的に何が言いたいかよく分からないですが ヒエッ……このスレは荒れる……
687 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 00:27:13.08 ID:YJk6tGcw.net] >moveならrvalueとして渡されるのでそこは理解してください rvalueになるのは移動の右辺であり3のケースでは(3がmoveになったとして)移動元のhogeの実体だが take_S()に渡るのはmoveされた後のhogeなのでtake_S()の中では問題無くlvalue扱い
688 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 00:28:49.03 ID:YJk6tGcw.net] しつれい、 誤: take_S()に渡るのはmoveされた後のhoge 正: take_S()に渡るのは&hogeからmoveされてきたhogeの「複製」
689 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 00:51:20.33 ID:5nx6GB9W.net] リンク先読んだ?
690 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 00:53:43.57 ID:YJk6tGcw.net] もとから読んでるっつーの;;; >>677 はムーブコンストラクタで構築されたオブジェクトがlvalueでないと思っちゃうタイプ?
691 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 00:54:17.11 ID:5nx6GB9W.net] 3.でmoveは発生しません 詳細はさっきのブログ記事に書いてあります 以上
692 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 00:55:29.24 ID:YJk6tGcw.net] >>679 どこか指摘できずに逃亡;;;
693 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 00:57:15.79 ID:5nx6GB9W.net] lvalueをmoveせよ さて、2. はどうしたらいいだろう。moveコンストラクタを実装したものの、コンパイラは2. の場合には、moveコンストラクタを呼び出してくれない。なぜなら、コンパイラは、プログラマの脳内仕様を読んではくれないからだ。tmpが、その後に使われていないかどうかは、コンパイラは静的に決定できないのである。 そこで、プログラマが意図を伝えてやらなければならない。 X b( static_cast<X &&>(tmp) ) ; この様に、rvalueにキャストしてやれば、moveコンストラクタを呼び出すことが出来る。
694 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 01:01:18.54 ID:YJk6tGcw.net] >>679 はSのインスタンスhogeを関数void take_S(S) (※void take_S(S&)ではない!)に渡す際に、 take_S()の呼び出し元(この場合main())が hogeと同じ値を持つインスタンスをtake_S()の引数用領域に構築する必要がある、というあたりからして理解していないのではないか;;; で、問題にしているコードはリンク先の >tmpが、その後に使われていないかどうかは、コンパイラは静的に決定できないのである。 には該当しない
695 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 01:04:39.70 ID:YJk6tGcw.net] なぜなら、今回のケースはコードを見たらワカルからじゃわ;;; コンパイラは静的に決定できない、と言っているのは停止性問題を解く万能のアルゴリズムが無いことから来ているが、 特殊なケースでは停止性問題は機械的に解ける 今こそその時、 、というあたりからして>>679 はちんぷんかんぷんなのではないか……
696 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 01:11:23.21 ID:5nx6GB9W.net] あーそこがわかってなかったのね take_Sの仮引数を実引数で初期化する時に同じことが起こるだけですよ? 実引数をrvalue参照とみなしてオーバーロード解決できればmoveで仮引数が初期化される できなければ(かつlvalue参照として解決できれば)copyで仮引数が初期化される
697 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 01:24:29.28 ID:YJk6tGcw.net] >>684 藻前の頭が固いだけなんとちゃうか;;; >実引数をrvalue参照とみなしてオーバーロード解決できればmoveで仮引数が初期化される この場合(すなわち実引数hogeをtake_S()の仮引数としてコピーした後呼び出し元が実引数hoge()を使わない(ことをコンパイラが機械的に判定できる)ケース) において、実引数hogeのアドレスをrvalue参照とみなしてはいけないという根拠は? 論理的にはソースコードの意味を変えることなく整合するんだけどそういう最適化はいけないことなの?
698 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 02:58:15.91 ID:YJk6tGcw.net] んまーとは言ったものの、 【実験1】 >>627 のコードをループにしてやって最適化「-O2」にしても"move"にならなんだorz https://wandbox.org/permlink/2kwbZ4cxyfMDe9VC 結果: default -------- copy 0, 1 default -------- copy 1, 2 ... ※ ループにした他、コピコンとムーブコンをそれぞれ「それらしく」実装もしてゐる、
699 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 02:59:10.66 ID:YJk6tGcw.net] 【実験2】 もちろんstd::move(hoge)したらmoveになる (上記リンク先のコードのDO_MOVE定義のコメントアウトを外してを有効化) 結果: default -------- move 0, 1 default -------- move 1, 2 ... 【実験3】 また、中間変数hogeを使わずtake_S(return_S())するとcopyもmoveも起きない (上記リンク先のコードのUSE_ITM_VARの定義をコメントアウトして無効化) 結果: default 0, 1 default 1, 2 ...
700 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 03:09:25.47 ID:YJk6tGcw.net] (言い訳1) 実験3のような最適化が許されるのだから、copyをmoveに読み替える最適化も許されるべきだ 規格に照らしてどうなのかはC++規格の専門家の反応待ち (言い訳2) 今回のケースでGCC様がcopyをmoveにする最適化を拒むのは、単にhogeの使用箇所の分析をサボっているか (データフロー解析の一環として論理的には十分take_S()呼び出し後の未使用を機械的判定をやれるはずなのに… 、デストラクタのdefault[] のコストでも気にしている可能性が微レ存 (言い訳3) >>627 のコードでmoveになる、と最初に言い出したのは>>609 であって漏れではない むしろ漏れは「場合によってはcopyが起きる」(>>623 )と述べてたのでcopy派である (C++17のRVOが要請するABIについて誤解していた感じなのでであんま大きな声では言えないが
701 名前:デフォルトの名無しさん mailto:sage [2021/07/11(日) 13:04:35.11 ID:G2C/uXds.net] >>685 > 論理的にはソースコードの意味を変えることなく整合するんだけどそういう最適化はいけないことなの? コピーコンストラクタとムーブコンストラクタのどっちが呼ばれたかわかるようにログ出力とかしてたら動作が変わる。 そういう副作用を含めてコンパイラが動作を変えていいケースは >>671 で挙げられたように明示的に規定されていて、 あなたの言うケースはそうではない。
702 名前:はちみつ餃子 mailto:sage [2021/07/11(日) 18:47:32.64 ID:8K44AFaV.net] >>688 Copy になるべき場合と Move になるべき場合は条件がはっきりしている。 どちらでもいい場合は無い。 表層上の動作が仕様通りであればどうコンパイルしても良いのが C/C++ なので、 あえて、あくまでもあえてレアケースを挙げるとすれば (見かけ上の) 動作が Copy でも Move でも同じだとコンパイラが見ぬくことが出来る場合が あったなら Copy の場面で Move 相当の機械語が生成されることが絶対にないとは言いきれないけども、 Copy でも Move でも同じだと確信できる場合に限られるので動作からはどうせ観測できない。 意味を変える最適化をしていいという唯一のルールがコピー (またはムーブ) の省略で、 その一部が C++17 では必須化されたわけだね。
703 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 07:46:00.62 ID:5HFqt1x5.net] ある整数がある整数の n 乗であることの判定ってどうするのが良いでしょうか (n も整数とします) 今までは x == (int)pow((int)pow(x, 1.0/n), n) で判定してたんですが、今の自分の環境で x = 4096、n = 6 を渡したら誤判定しました (int) を round に変えるのを思いつきましたが、コーナーケースがあったら嫌なので、他の良い方法があったら教えてください
704 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 08:17:32.01 ID:K0Wntvol.net] >>691 諦めてboostの多倍長整数を使う。
705 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 08:25:49.14 ID:Vv9VoiuP.net] >>691 double y = pow(x,1.0/n); int iy = (int)y; iy==y このほうが多少マシにはなると思うが根本的な解決になってないので double epsilon = 0.00000001; y-iy < epsilon; にするとか
706 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 09:45:03.47 ID:Q0n0f8DA.net] >>691 どこまで高速化したいのかわからんけど頑張ってn乗計算するとか https://qiita.com/b1ueskydragon/items/0b8e0c382d782423c6d3
707 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 10:01:12.57 ID:5HFqt1x5.net] >>692 多倍長整数でどうやるんでしょうか? >>693 確かに、改めて n 乗する意味なかったですね >>694 後出しですみませんが、遅くて良いから短くて誤判定のないのが望ましいです
708 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 10:11:36.07 ID:5HFqt1x5.net] >>693 y の小数部分が 0.9999999998 とかだと失敗しますよね? iy = round(y) として abs(y - iy) < 1e-12 で判定しようかなと思います
709 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 10:22:44.45 ID:D0qCNAQT.net] >>690 最後だけ認識おかしい、唯一ではない
710 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 12:24:08.89 ID:uJpO0uZ2.net] >>697 他に何かあるなら教えて。
711 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 12:35:12.60 ID:4jaglyfV.net] >>695 boost 多倍長整数 冪乗 で検索。 書くのは色々と面倒だから、解説ページ読め。boost はpowも対応している。
712 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 17:41:28.01 ID:D0qCNAQT.net] >>698 わかりやすいとこで言えばStrict Aliasing Rulesとか 型が違おうが何だろうが、本来一度書いたものが、次別のポインタ(or参照)を読む時
713 名前:同じ場所だったら、さっき書いた値になってなければならない ・・・んだが、そんなこと守ってたら最適化なんかほとんど出来ないだろ 他にC++の仕様に規定されてなくとも各コンパイラは色々やってる 大抵は問題ないが、ごくまれに意図した挙動になってくれなくて困ることはあるぞ [] [ここ壊れてます]
714 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 18:26:33.31 ID:3yd7dMb1.net] >>691 >>692 アホな文系の質問にアホな文系が答えるスレ? どの値が与えられて、その値の条件(範囲、符号、...)は何か 環境は仮定していいのか、(C++の規格範囲内の)すべての環境で正しく動作する必要があるのか コードに求めるものは何か?(可読性、速度、...) をはじめからすべて書きなさい
715 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 18:32:42.82 ID:3yd7dMb1.net] ごく一般的なPC環境で、与えられた整数がintの範囲であれば、 (ある程度の判別を行ったあと)普通に四捨五入で良い n乗根の候補を求めたあと整数領域でn乗してもいいし 元の数を(割り切れる判別をしながら)候補で割っていってもいいし 与えられた整数が32bitの範囲であれば、2分検索やリニア検索してもいい アホな文系が理解できる範囲で自分の頭で考えて自分の責任でコードを書きなさい
716 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 19:47:47.34 ID:F4g5ptiT.net] >>701 そういった諸々の細かい調整を諦めて多倍長整数を使う、ということだよ。 そもそもの要件(n乗判定)でpowを使う乱暴さを考慮すれば、面倒な部分を処理してくれるライブラリを使用するのは有力な選択肢。それを無視して「アホな文系」とは言ってくれる。 ご高説を宣ってくれた後にどんな素晴らしい解説を>>702 でしてくれるのかと思ったら、n乗判定にわざわざ割り算を持ち込んだり、対数にも触れずに検索にフッ飛ぶ滅裂ぶり。>>601 が混乱するのを笑うために書き込んでいるとしか思えん。 文系、文系と馬鹿にする人間は、人間と会話のできない発達障害が多いのかね?
717 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 20:05:16.58 ID:3yd7dMb1.net] ヒント 多倍長整数を使っても何も解決しない
718 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 20:29:50.05 ID:4jaglyfV.net] >>704 なんで解決しないのか解説してもらいたいねぇ。
719 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 20:34:24.53 ID:rFlF3L7g.net] 累乗根は浮動小数点の演算だからだよ
720 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 20:52:49.79 ID:xS7m7lUb.net] いや累乗して整数同士で比較すりゃええやん
721 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 21:00:52.19 ID:+DCDGa5F.net] n乗数判定は明らかに整数論の問題なんですがそれは なお一番簡単な平方数判定でもNPなんで(一発でポンと答えが出る楽な方法は多分)ないです
722 名前:デフォルトの名無しさん [2021/07/12(月) 21:13:08.21 ID:q3a62lD+.net] 因数分解してハッシュで数えて全部6の倍数なら何かの6乗なんじゃないの 4096=2^12 h{2}→12個 12は6の倍数なので何かの6乗 3*7*3*7*3*7*3*7*3*7*3*7 = 85766121 だと h{3}→6個 h{7}→6個 両方6だから何かの6乗
723 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 21:14:32.03 ID:M5TNNHP+.net] 累乗根の演算で引数の逆数をどうやって整数で表現するの? >>691 の例で言えば、n=6なら6乗根(=1/6乗)の計算を行なっている
724 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 21:21:35.61 ID:uJpO0uZ2.net] >>700 未定義動作となる場合はそもそも「意味」が定まらないので「意味を変える最適化」とかいう話にならないよ。
725 名前:デフォルトの名無しさん [2021/07/12(月) 22:14:22.14 ID:vW8lyXRJ.net] ひさしぶりにみると すごく カオスなスレッド
726 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 22:33:30.20 ID:j4Yh95VG.net] >>709 >>702 が言ってるのがそれじゃ無い? > 元の数を(割り切れる判別をしながら)候補で割っていってもいいし 2で割り切れなくなるまで割り、割った回数がnの倍数で無ければNG 3で割り切れなくなるまで割り、割った回数がnの倍数で無ければNG を繰り返すって事かと(多分)
727 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 22:51:10.50 ID:MoTlox7M.net] 数値計算としては>>693 ,696がもっとも正統派の方法だよ 素直に累乗根を求めて誤差を評価して判定する わざわざトリッキーな手段を採る必要性は無い
728 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 23:38:51.54 ID:PjBVtdER.net] >710 「 累乗の判定」と「 累乗根の演算」をごっちゃにしている? 「累乗根の演算」はあくまで「 累乗の判定」の候補となる整数を 見つける手段の一つで、必ずしも必要ではない。 極端な話、候補となる整数を2から順番に数えて判定しても良い。 まあ、「できるだけコードを簡単に」という話なら素直に累乗根を 使ったほうが良いけど、その時でも(累乗/累乗根計算の誤差の問題から) 「 累乗の判定」を行う必要がある。 >693 >714 よくよく>691を見たら、本質的にはintによる切り捨ての問題だな。 0.5を足して実質的に四捨五入になるようにすりゃいい。 >691の計算を下敷きにするなら int y = pow(x, 1.0/n)+0.5;//<-これ重要 int z = pow(y, n)+0.5;//<-これも重要だと思う として、 x == z を判定すりゃいいんじゃね? 試してないけど。
729 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 23:48:10.49 ID:3yd7dMb1.net] 長々と書いてやっと質問者と同レベルに追いついた アホな回答者 全部>>702 に書いてるし
730 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 23:51:52.50 ID:3yd7dMb1.net] ある整数やnがマイナスの場合に言及してるのは>>701 だけ 質問者も他の回答者もそこまで頭がまわらない
731 名前:デフォルトの名無しさん mailto:sage [2021/07/12(月) 23:57:47.66 ID:xS7m7lUb.net] そっかあ あたまがいいんだね
732 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 00:17:32.29 ID:u8F7J+OY.net] >>699 いや、 整数 x、y、n が与えられたときに x が y の n 乗であるかどうか判定する ではなく、 整数 x、n が与えられたときに x が y の n 乗となるような整数 y があるかどうか判定する ですよ? 多倍長整数なんて出る幕ないでしょう もしかして y を全ての自然数について全探索するのを想定してる? 高卒?
733 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 00:31:12.29 ID:u8F7J+OY.net] >>701 質問者自身が int にキャストとか round とか言ってるんだからどう見ても自然数の話でしょ バカ >>702 > n乗根の候補を求めたあと整数領域でn乗してもいいし > 元の数を(割り切れる判別をしながら)候補で割っていってもいいし なんで今更質問者(>>696 )より筋の悪い方法を提案するの?笑 > 与えられた整数が32bitの範囲であれば、2分検索やリニア検索してもいい これしきの問題で何を探索することがあるんだよバァ〜〜〜カ つーかわざわざ二分探索とかするならそれこそ桁数めっちゃ多いときの方が有効だろ なぜ32bitに限った?
734 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 00:34:18.46 ID:u8F7J+OY.net] >>707 えっっっっ やっぱり根を探索するつもりだったんだ ヤベーなお前
735 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 00:38:55.05 ID:u8F7J+OY.net] >>708 何と勘違いしてんのか知らんが、ここで与えられてる問題は桁数 n に対して明らかに O(n) で解けるだろ アホ
736 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 00:45:05.26 ID:u8F7J+OY.net] >>715 質問者より数歩後ろを歩いてるのにすごく堂々としていてかっこいいです
737 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 00:54:56.07 ID:lAJ4enjR.net] 構ってほしいなら昨日のID教えてよ
738 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 01:00:26.91 ID:2F1zpnof.net] ウーン、質問者!w
739 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 01:00:52.89 ID:MEdkoaBM.net] >>711 アホだろお前
740 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 01:02:39.35 ID:+UxqO86S.net] そうでもないよ。
741 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 01:28:13.49 ID:bx8BDdOP.net] >716 あれ? もしかして>702? >702は回答としてもヒントとしても全然駄目じゃない? >695の問題の本質はstd::powの誤差の発生の仕方(プラスマイナス両方出る)と double -> int キャスト時の誤差切り捨て(0に近づく方に切り捨て)の ミスマッチなのに、>702ではそんなこと何も言及していないよね。 もしこれで「書いている」と感じるようなら、もっと人間に説明する方法を 勉強したほうが良いと思うよ。
742 名前:728 mailto:sage [2021/07/13(火) 01:31:47.96 ID:bx8BDdOP.net] 自己フォロー >695の問題の本質はstd::powの誤差の発生の仕方 1.0/nでも誤差発生しているか。std::powとどっちの誤差がデカイかね?
743 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 01:38:26.00 ID:2F1zpnof.net] もしかしてっつーかモロID一緒じゃん あとみんな分かってることを周回遅れで「本質」として宣言すんなって あと安価間違いし過ぎ ホント迷惑だからもうやめとけ
744 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 01:39:24.44 ID:u8F7J+OY.net] boost多倍長整数クン顔真っ赤でワロ
745 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 02:08:48.23 ID:FVC0BsAk.net] この中のどれがQZがコテ外して書き込みしているのか想像したら(*´艸`*)
746 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 02:10:33.69 ID:RS3RIqhF.net] >>668 これとか完全に荒らしのやり口だもんな
747 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 02:30:29.04 ID:bx8BDdOP.net] >730 誤差の発生の仕方と誤差切り捨てのミスマッチが問題ということが分かっているなら、 なんで>691への回答でそれを指摘しないの? この話で重要な「切り捨て」という単語すらスレで3回しか出てきてないし。 それにdoubleに0.5足して/引いてからintにキャストとかCで誤差を扱うときの 定石だろうに、0.5bニいう数字自体bルとんど出てこbネい。 結局>691に助言したいんじゃなくてマウントしたいだけだから当然か。 分かってて余計な説明しかしないんだから、なんとまぁ不親切なやつなんだろうかね。 さて、書きたいこと書いたので風呂入って寝るかね。
748 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 02:42:44.22 ID:2F1zpnof.net] >>734 round という語が出た回数とその場所も調べたまえ 指摘するまでもなく質問者は>>691 ,696にして早々それに気付いている
749 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 03:09:56.56 ID:itar1i0e.net] そもそも>>696 の処理であれば切り捨て誤差は発生しない round() と abs() の2段構えで対策はされてるよ 0.5 を加算するよりずっとスマートな記述だな
750 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 03:11:08.93 ID:itar1i0e.net] 被った すまん
751 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 07:55:39.92 ID:Fq8PEpca.net] >>728 四捨五入ってわかるかな? 質問者が分かってることがわかるからそれだけ書けば十分 分かってないのはお前だけ >>720 小数の誤差を見積もれない、見積もるのが面倒 というなら整数領域だけで答えを導く方法もある 頭の悪い文系にはそういう発想は出てこないかな? intも整数もマイナスの数を含むんだよね定義的には 範囲を確認するのは当然 質問者も含め勝手な思い込みはバグの元
752 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 09:33:54.05 ID:53YTa3I7.net] Pow(x, n) ... n乗 Pow(x, 1.0/n) ... n乗根 Pow(x, -n) ... n乗の逆数 Pow(x, -1.0/n) ... n乗根の逆数
753 名前:デフォルトの名無しさん [2021/07/13(火) 12:07:43.02 ID:WUJYnH4r.net] >>712 どんなときでも共通するのは声が大きい香具師が勝つ その場の空気を支配した香具師が勝つ そしてマスゴミによって印象操作された世界の完成
754 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 12:13:28.49 ID:2uidM73f.net] >>740 その発想は朝鮮人の考え方 最終的には真実が勝つ
755 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 12:25:14.06 ID:o0P+1kd0.net] 整数の問題なら実数近似せず y=x^n で(n=1,2,3,4,5....)を比較してくのが基本だろ 高速化するなら多少のテクニックはあるけどたかだか32〜64bitの範囲 どうってことない
756 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 12:33:54.00 ID:Sa7UmWqZ.net] >>742 癪だが>>719 が問題を一番正確に表現できているからもう一回よく読め
757 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 12:34:17.81 ID:u8F7J+OY.net] 規格には拘りがあるが数値計算やアルゴリズムの知識はまるでない基地外の狂宴
758 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 12:49:36.15 ID:o0P+1kd0.net] >>743 えーなんだこれ つまり x,nが与えられたときx^1/nが整数かどうか?を示すってことか y^n=xに変換すればなんにせよ整数の探索問題 実数にする必要もない
759 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 13:03:24.24 ID:u8F7J+OY.net] >>745 それ、キミの言ってる32〜64bitの範囲だと尚更>>696 と比べたときにメリットないよね???笑笑笑
760 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 13:07:00.03 ID:u8F7J+OY.net] 上にも「32bitくらいなら探索すれば〜」とか言ってるアホいたが、なぜ多倍長でもない限り探索するメリットなんてないってわからないんだキミたちは(泣)
761 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 13:25:56.92 ID:Ag1Q4SdR.net] >>741 朝鮮人に詳しいんですね!! 感動しました!!!
762 名前:デフォルトの名無しさん [2021/07/13(火) 14:47:47.54 ID:OYlFgj5O.net] つまりそれってint型の整数の範囲でn乗がなんであってもεは1E-12で充分だと保証してから使うの? 要するにεは絶対にそれでいいのか?
763 名前:デフォルトの名無しさん [2021/07/13(火) 15:54:31.17 ID:WUJYnH4r.net] >>744 QZか?MZか?片山か?
764 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 18:43:03.58 ID:Fq8PEpca.net] >>747 整数ドメインで行うメリットはいろいろとある ・アホな文系でも理解できる (誤差の見積もりが不要) ・整数演算の方が圧倒的に速い環境 (ARM-M3など) ・浮動小数点演算ライブラリによるコードサイズ増加を防ぐ (チープなマイコン対応) ・doubleが32bitな環境への対応 ・64bit整数への対応 選択肢は多いほど良い
765 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 18:48:11.59 ID:Fq8PEpca.net] > ごく一般的なPC環境で、与えられた整数がintの範囲であれば、 > (ある程度の判別を行ったあと)普通に四捨五入で良い ごく普通の環境、ごく普通の頭ならこれで終わり
766 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 19:39:45.09 ID:gA5oZqd8.net] 昔"文系"にいじめられてた可愛そうな子なんです
767 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 19:58:16.23 ID:xjdnjcKm.net] 整数演算の最大のメリットがリストに挙がってないのは何でかな
768 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 20:18:44.42 ID:Fq8PEpca.net] >>753 「アホな文系」≠「文系」 >>754 ぜんぜん最大のメリットじゃないからだな
769 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 20:20:09.92 ID:Fq8PEpca.net] >>750 団子のことも忘れないでください
770 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 20:25:35.22 ID:xjdnjcKm.net] >>755 あー・・・何のことか分からねえで言ってるな
771 名前:デフォルトの名無しさん [2021/07/13(火) 20:29:09.24 ID:OYlFgj5O.net] 最大のメリットって何だ?
772 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 20:35:59.66 ID:xjdnjcKm.net] からかいたくなったから焦らすぜ アホかどうかは関係ないことさ
773 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 22:54:45.19 ID:hgVyntNx.net] >>755 アホな文系に虐められてたんだね…😢
774 名前:デフォルトの名無しさん mailto:sage [2021/07/13(火) 23:05:28.90 ID:u8F7J+OY.net] >>752 それは質問者が質問時に自分で言ってることなので……(苦笑)
775 名前:デフォルトの名無しさん mailto:sage [2021/07/14(水) 05:08:53.51 ID:T6a5Tff4.net] hoge がビルドされてて hoge.h があるシステムでは hoge を呼び出し、そうでなければ何もしない関数 call() ってどう書くべきてすかね? これまでは #if __has_include(<hoge.h>) #endif で分岐してたんですが、これだと if に該当しなくてもコンパイラは #if #endif で囲まれてる部分を読み込むし、そこに hoge(); という文があれば「hoge() なんてないよ」というエラーが出ます 該当しない場合は if の中を読み飛ばすとかできますかね?
776 名前:デフォルトの名無しさん mailto:sage [2021/07/14(水) 07:18:49.74 ID:l4qXoRve.net] __has_includeはインクルードされたかどうかじゃなくて、 そのファイルが存在するかどうかを判定するやつだからね hoge.hの中で #define HOGE_LOADED して、呼び出し側で #if defined(HOGE_LOADED) call(); #endif って感じかな
777 名前:デフォルトの名無しさん [2021/07/14(水) 07:40:27.18 ID:l4qXoRve.net] hoge.hの中を編集できないなら、 読み込み: #if __has_include(<hoge.h>) #include <hoge.h> #define HOGE_LOADED #endif 呼び出し: #if defined(HOGE_LOADED) call(); #endif
778 名前:デフォルトの名無しさん mailto:sage [2021/07/14(水) 08:03:52.87 ID:wXBQSN5l.net] >>761 だったらコーナーケースが無いこととその理由を解説したら?
779 名前:デフォルトの名無しさん mailto:sage [2021/07/14(水) 11:41:16.26 ID:b1WA6GgP.net] >>765 お前QZだろ コテ外すな
780 名前:デフォルトの名無しさん mailto:sage [2021/07/15(木) 00:20:47.29 ID:Fm/xoZyi.net] >>763 ありがとうございます。 hogeがそのシステムでビルドされてるかどうかの判定は、外部ツールか自分の目に頼らないと無理ですよね?
781 名前:デフォルトの名無しさん mailto:sage [2021/07/15(木) 00:40:53.25 ID:y+mqrw+D.net] 自作自演w
782 名前:デフォルトの名無しさん mailto:sage [2021/07/15(木) 05:48:49.27 ID:GxcfqrJG.net] >>767 > hogeがそのシステムでビルドされてるかどうか hoge.lib, hoge.dllとかが存在するかどうかを調べればいいだけだとすると 見つかったかどうかをコンパイル時にフラグ(-DHOGE_LIB_FOUND)として渡せれば C++内で#if defined(HOGE_LIB_FOUND)みたいにして使える。 (これはコンパイル時のことだからC++だけでは普通無理だとおもう)
783 名前:デフォルトの名無しさん mailto:sage [2021/07/15(木) 06:31:17.96 ID:CtTYgJ1T.net] C++よりcmakeとかビルドツールのお仕事だと思う
784 名前:デフォルトの名無しさん mailto:sage [2021/07/15(木) 09:10:44.89 ID:Fm/xoZyi.net] >>769-770 あざす!
785 名前:デフォルトの名無しさん mailto:sage [2021/07/15(木) 18:30:18.77 ID:HJCZYZ96.net] Unifyde Call Syntax FOREVER!!!!!!!
786 名前:ハノン mailto:sage [2021/07/15(木) 20:57:38.68 ID:kDBlsdNK.net] >>695 多倍長なら是非是非、こちらを参照あれ、一応 C++ で完結している多倍長演算ライブラリです! https://mevius.5ch.net/test/read.cgi/tech/1434079972/37
787 名前:ハノン mailto:sage [2021/07/15(木) 20:58:44.86 ID:kDBlsdNK.net] >>712 なに、いつものことですよ‥‥
788 名前:ハノン mailto:sage [2021/07/15(木) 21:00:08.01 ID:kDBlsdNK.net] >>732 残念ながらハズレ
789 名前:ハノン mailto:sage [2021/07/15(木) 21:02:01.21 ID:kDBlsdNK.net] >>756 私は忘れていませんよ
790 名前:ハノン mailto:sage [2021/07/15(木) 21:02:27.40 ID:kDBlsdNK.net] >>766 ちがうよね‥
791 名前:デフォルトの名無しさん mailto:sage [2021/07/15(木) 22:53:15.98 ID:2Mj48wOt.net] QZ現る
792 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 00:17:25.62 ID:37KQZYs3.net] >>773 積の実装はどのアルゴリズムで?
793 名前:ハノン mailto:sage [2021/07/16(金) 04:05:20.77 ID:6W3ohAQ3.net] >>779 筆算法‥‥1 bit × 1 bit を筆算するやりかた、非乗数をシフトしながら乗数のビットが1 のときアーキュムレータに足す、というO(n^2) のものです、「乗法を加法の繰り返しにする」よりはましかと 課題はカラツバ法に直すことですが、まだ出来ていません
794 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 04:11:57.42 ID:37KQZYs3.net] >>780 では、話になりませんのでそんなもの勧めないでいただけますか
795 名前:ハノン mailto:sage [2021/07/16(金) 04:43:48.91 ID:6W3ohAQ3.net] >>781 他の方が優れたソースコードを提示していただければ、私のは引っ込めますけれどもね
796 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 04:57:11.80 ID:N9xjQvrw.net] 多倍長整数ならそれこそboostで良いでしょ 高速な畳み込み演算がしたいなら整数環上でFFTします つーか精度の観点から言っても速さの観点から言っても一択でしょ(なんでカラツバ?) そもそも、話の流れからして多倍長整数勧めるのもおかしいし 話わかってないなら出張るなよ せっかく隔離用の個人スレ (本来ならこれも甚だ迷惑な存在だが) があるんだから、そこで永久に一人でやっててよ
797 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 05:01:00.91 ID:teDb7k99.net] >>782 https://www.google.com/search?q=%E5%A4%9A%E5%80%8D%E9%95%B7%E6%95%B4%E6%95%B0+FFT
798 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 05:06:07.44 ID:+GJR5l7e.net] カラツバ法はやばい せめてフーリエだ すでにあるmpirとかいうやつでいいだろ
799 名前:ハノン mailto:sage [2021/07/16(金) 05:16:00.53 ID:6W3ohAQ3.net] >>784 ちゃんとコンパイルできるコードはどれですか?
800 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 05:18:43.72 ID:37KQZYs3.net] ワロチ 既知の事柄のサーベイ能力も低いときた
801 名前:ハノン mailto:sage [2021/07/16(金) 05:36:01.54 ID:6W3ohAQ3.net] >>787 サーベイ能力が低いのは認めます、お願いですから、そのままコンパイルすれば動くコードを教えてください
802 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 05:58:14.27 ID:N9xjQvrw.net] >>783 は読めねーのかよ気狂い
803 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 06:18:07.75 ID:qtVJ0qYe.net] こんなスレまで来てC++の話してるくせにboost知らないってマジかよ…
804 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 09:21:02.78 ID:s4+8hxkm.net] QZというコテは叩かれやすいからカノンにしたのか
805 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 09:57:20.84 ID:KEhhoM0/.net] 略してQアノン
806 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 11:50:57.63 ID:/EXEczMl.net] コテを変えても頭の悪さは相変わらずなんだな まあ中の人が同じなんだから当然だけど
807 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 12:07:04.82 ID:EpGpWKJL.net] 頭悪いのは別にいいんだが、マナー違反が深刻に多いんだよ ・質問に頓珍漢なレスをつける (そもそも回答側に立つのがおこがましいし) ・話題に関係なく自分の創作物を押し付ける ・個人用としてしか機能していないスレを保守し続ける ・都合悪いレスは当然無視 ・>>668 人間性が劣悪なのが透けて見えるから本当にキツい
808 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 12:09:38.94 ID:EpGpWKJL.net] 全然関係ないが>>259 ,789が一ヶ月のときを経て同じIDなのって偶然? それともID被りってプログラム的にもっともらしい理由付けあるんだっけ?
809 名前:デフォルトの名無しさん [2021/07/16(金) 13:36:58.69 ID:tbXedaSH.net] フリーランスに立ちはだかる「常駐」の壁。慣例を打ち壊し、 “テレワーク”案件3割→8割へと成長を遂げた「クラウドテック」の軌跡 https://prtimes.jp/story/detail/DBnPOktyljr テレワークの一般化により、11月にはテレワーク可能案件83.7%へと増加。 2021年、フリーランスのトレンドは「移住&テレワーク」と予測 https://prtimes.jp/main/html/rd/p/000000045.000050142.html リモートワーク求人専門サイト「プロリモート」がリニューアルオープン、業務委託契約の求職者と企業をマッチング https://www.value-press.com/pressrelease/262778 1/3以上が採用につながる高マッチング率、リモートワーク×エンジニア・デザイナー専門の 人材紹介サービス「ReworkerAgent」正式リリース場所からも時間からも自由な働き方を実現! https://www.nishinippon.co.jp/item/o/713384/ 新潟県、移住してきたテレワーカー/フリーランスに最大50万円を支給 https://internet.watch.impress.co.jp/docs/news/1287094.html 茨城県日立市、県外からの「テレワーク移住者」に最大151万円の助成金 https://internet.watch.impress.co.jp/docs/news/1281120.html 長野市、市内に移転・事業所設置し、移住することで最大550万円の支援金を支給 https://internet.watch.impress.co.jp/docs/news/1274735.html フリーランスが活用できる「最大1,000〜3,000万円・補助率50%〜75%」の 『ものづくり・商業・サービス補助金』とは?概要や条件を解説 https://freenance.net/media/money/4255/ 『ReWorks(リワークス)』リモートワーク特化型転職サイトとして 3月5日 リニューアル https://prtimes.jp/main/html/rd/p/000000051.000010457.html
810 名前:デフォルトの名無しさん [2021/07/16(金) 16:34:47.56 ID:6/LQ7Fle.net] >>795 ID被りはわりとまじでたまにある
811 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 18:25:58.33 ID:X0WexOAj.net] キャッシュの衝突みたいなもんだろ
812 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 18:26:37.20 ID:X0WexOAj.net] ハッシュなw
813 名前:ハノン mailto:sage [2021/07/16(金) 19:28:22.91 ID:6W3ohAQ3.net] >>794 >・質問に頓珍漢なレスをつける (そもそも回答側に立つのがおこがましいし) いいんです、話題を拡散させるのがねらいだし >・話題に関係なく自分の創作物を押し付ける たしかに見たら馬鹿になるかもしれませんから、各自お気を付け遊ばせ >・個人用としてしか機能していないスレを保守し続ける いつでも本来の用途に使えるのですよ、有償で問題を片付けるスレ、としてよろしく >・都合悪いレスは当然無視 無視することによるデメリットを引き受けるのなら当然でしょ? >・>>668 まあこういうのはやめるようにします、ごめんなさい
814 名前:ハノン mailto:sage [2021/07/16(金) 19:32:12.26 ID:6W3ohAQ3.net] >>783 それって裏で GMP を読んでいるだけでは? そして GMP はアーキテクチャー依存ですよね?
815 名前:ハノン mailto:sage [2021/07/16(金) 19:32:52.60 ID:6W3ohAQ3.net] >>789 >>901
816 名前:ハノン mailto:sage [2021/07/16(金) 19:38:06.89 ID:6W3ohAQ3.net] >>801 ああ、GMP だけではないようですね MPFR, MPIR MPC とか、でも、どれもアーキ依存にみえますけれども、実際どうなんでしょうね‥‥
817 名前:ハノン mailto:sage [2021/07/16(金) 19:41:03.47 ID:6W3ohAQ3.net] >>791 選ブラのデフォを他分野のコテにしたのです、そっちでもキチガイピアニスト扱いですが、まあ、いいか‥‥
818 名前:デフォルトの名無しさん mailto:sage [2021/07/16(金) 19:49:34.02 ID:+QzOnEF5.net] ピアノも弾けないのにピアニストとはこれいかに?
819 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 00:31:45.93 ID:uZE7YjUc.net] >>800 全部開き直りじゃねーか 迷惑だなあ
820 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 00:37
] [ここ壊れてます]
821 名前::22.71 ID:i16o/xCs.net mailto: >>795 ,797-799 ただのIDなら良いんですが、これ両方とも自分のなんですよね…… 2ch側で同じ人間の書き込みを紐付ける仕組みがあったとしたら怖くないですか? しかもその人が RONIN 利用者だったりしたら…… 2013年8月の「2ちゃんねる個人情報流出事件」を彷彿とさせますね [] [ここ壊れてます]
822 名前:はちみつ餃子 mailto:sage [2021/07/17(土) 03:16:29.97 ID:GNWgh0W+.net] >>807 ID 生成アルゴリズムについて出ている情報はかなり前のものなんで 今でも同じかどうかはわからんけど、わかっている範囲では偶然としか言いようがない。 何度もあれば話は別だが一回あっただけでは偶然ではないと考える人はいないよ。 ただ、 2003 年頃から生のIPアドレスを記録することは明言されているので、 プロバイダの協力があればどのデバイスから書き込んだのかは特定できる。 今では 2ch はいわゆるプロバイダ責任制限法が言うところの 特定電気通信役務提供者に該当するはずなので 必要なときに個人情報を提供できる体制は事実上の義務なんだよ。 書き込み内容に権利侵害があったときに個人情報を提供することで掲示板運営者は 責任を制限されるという法律なので 2ch の側で責任をかぶる覚悟がない限り 書き込み元の情報を残さないという態度は取れない。
823 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 03:26:32.94 ID:+M7J9sQi.net] 別スレでも同じ現象を見た 6/3と7/16はどういうわけか同じIDとなっていたようだ
824 名前:はちみつ餃子 mailto:sage [2021/07/17(土) 03:56:04.37 ID:GNWgh0W+.net] >>809 ID の生成元は ・ IPアドレス (のハッシュから一部のバイトを取り出したもの) ・ 毎日更新されるランダム値 ・ 板名 をくっつけてハッシュをとったものとされている。 IPアドレスとランダム値が同じであれば ID も同じになる。 たまたまその日が同じランダム値だったのかもね。
825 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 05:58:32.38 ID:OBAxlXTB.net] 範囲for文ってompで並列化できるの? 自作コンテナを走査したいとしたら、なんか満たすべき条件ある?
826 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 06:23:13.20 ID:l7v2uVky.net] やってみりゃいいじゃん
827 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 13:21:42.77 ID:0jiuXQpQ.net] chrono で測ったn並列プログラムの実行時間が実世界で経過した時間のn倍になってる気がして、これが正しいかどうか調べたいんですが、ストップウォッチで測って比較するしかないですか ちなみに並列化はopenmpでやってます
828 名前:デフォルトの名無しさん [2021/07/17(土) 16:14:23.13 ID:eTC1af8g.net] バカノンノン
829 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 16:18:43.54 ID:DE+0Jqb8.net] >>813 https://letmegooglethat.com/?q=%E6%99%82%E9%96%93%E8%A8%88%E6%B8%AC+c%2B%2B
830 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 17:58:37.00 ID:z0Sx2PLf.net] え、chronoなり何なりで測った時間がおかしい、って話じゃないの? そら検証したけりゃ別スレッドやプロセスで測るなりストップウォッチなりだろう、と思ってたんだが ただまぁ経過時間の加算とかでおかしなことになってるのを真っ先に疑うべきだね
831 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 19:11:08.33 ID:cBM+BeK7.net] 時間測定クラスはシングルトン使ってるよね? どうせ複数の箇所で測定したのを加算してるってオチでは マルチスレッドならmutexか何かでnewの所をロックしないとおかしくなるし
832 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 19:36:36.54 ID:txbUHFZy.net] 実行時間といってるのがCPU時間のことならn並列でn倍になるからね メインスレッドのCPU時間だけを見るべき かんたんなんだしストップウォッチで測ればいいじゃん
833 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 22:27:23.07 ID:gI+aCVlx.net] スレッド毎にcronoした結果をnスレッド分足したらn倍になりそう……
834 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 22:30:43.79 ID:gI+aCVlx.net] WindowsならGetTickCount()でも使うところだけど (実質15.6 ms(PCによっては10 ms?)を超える分解能にならないのはおくとして) C++標準でms単位のカウンタってあるます
835 名前:? [] [ここ壊れてます]
836 名前:デフォルトの名無しさん mailto:sage [2021/07/17(土) 22:44:14.11 ID:z0Sx2PLf.net] chronoで分解能決めれるやんけ
837 名前:ハノン mailto:sage [2021/07/18(日) 00:41:49.86 ID:9YAoR/6C.net] >>691 私も試してみましたが、結局 >>694 の言うとおり実際に n 乗して験算するしかないかなぁ‥‥と思いました 私の環境でも、x == (int)pow((int)pow(x, 1.0/n), n) では散々 https://ideone.com/AXH87Q 次のようにすると、わりといい感じです https://ideone.com/NM2btt せっかく多倍長演算の話が出たので、もしも暇とやる気があったら boost::multipricise と GMPの c++ 記述と、例の自作のやつとに載っけて試してみます
838 名前:デフォルトの名無しさん mailto:sage [2021/07/18(日) 02:35:57.32 ID:pNZOhAQw.net] >>818 これ たとえばmain()の最初と最後のchrono::system_clock::now()の差で時間を計測してると仮定して、その間でnスレッド走らせてそれぞれt秒かかったとしたら結果はnt秒になる
839 名前:デフォルトの名無しさん mailto:sage [2021/07/18(日) 10:01:58.21 ID:WbmfjGIN.net] >>823 >その間でnスレッド走らせてそれぞれt秒かかったとしたら結果はnt秒になる なんで? chrono::system_clock::now()は現在時刻を返すと書いてある 仮に消費したCPU時間だとしても、スレッドの本数分ではなく高々論理コア数倍までで収まりそうに思ーう
840 名前:デフォルトの名無しさん mailto:sage [2021/07/18(日) 11:33:46.95 ID:/c4qfmiI.net] まあCPU時間と勘違いしてるんだろうね
841 名前:デフォルトの名無しさん mailto:sage [2021/07/19(月) 13:10:18.03 ID:whuO5wb3.net] g++で、-static オプションを付けたときにリンクされるライブラリのパスってどうやって指定するんですかね? システムにインストールされてる glibc が不具合を抱えてるので、$HOME/local に別バージョンの glibc をインストールしました 動的リンクの場合は -Wl,--dynamic-linker=$HOME/local/lib/ld-linux-x86-64.so.2 を渡すことで問題なくコンパイル・実行できたのですが、静的リンクを使用する場合どうしたら良いのかわかりません
842 名前:デフォルトの名無しさん mailto:sage [2021/07/19(月) 17:28:07.02 ID:ddBZ8vH3.net] >>609 一番上はコピーだぞ
843 名前:デフォルトの名無しさん mailto:sage [2021/07/20(火) 07:03:16.39 ID:ouQfIwtX.net] >>826 これLinux板のくだ質とかで聞いた方が良いですかね? スレチでしたら移動します
844 名前:デフォルトの名無しさん mailto:sage [2021/07/24(土) 08:11:39.12 ID:jjSVv9BX.net] >>811 普通にできるよ > 範囲for文のOMP並列化 ランダムアクセス不可能な自作クラスは常識的に考えて無理だろうけど 詳しい人いたら教えてくんろ
845 名前:デフォルトの名無しさん mailto:sage [2021/07/25(日) 16:30:34.85 ID:m1WCNOY9.net] 全員死んだの?
846 名前:デフォルトの名無しさん mailto:sage [2021/07/25(日) 17:00:04.04 ID:DW9TtY2c.net] g++ があんまり本気じゃなくて萎えるんだよね 並列化のとこ
847 名前:デフォルトの名無しさん mailto:sage [2021/07/25(日) 17:20:27.49 ID:Wj/gwJho.net] 誰がメンテしてるかわからんがリナスも当時g++の出来の悪さにぶちギレて依頼、C++はクソの一辺倒を貫いてる
848 名前:デフォルトの名無しさん mailto:sage [2021/07/25(日) 17:26:02.39 ID:Wj/gwJho.net] firefoxとかもそうだけど、有志がサポートするソフトってそれをメンテしている人間が無能の働き者だと最悪ゼロから作り直さないと逝けなくなるところが怖いところやな
849 名前:デフォルトの名無しさん mailto:sage [2021/07/25(日) 17:31:37.94 ID:DW9TtY2c.net] 元々はハッカーが「気合い入れる」祭りみたいなもんだったのに いつしか過去バージョンとの互換性がどうたらで硬直化していった そういうところはマイクロソフトやIBMに任しときゃいいのに リスクを承知で面白みという
850 名前:<潟bトを捨てちまいやがって [] [ここ壊れてます]
851 名前:デフォルトの名無しさん mailto:sage [2021/07/25(日) 17:34:19.95 ID:Kn/tUAQv.net] > メンテしている人間が無能の働き者 怖がらなくて良いぞ 彼らはお前より有能だから そして世間を怖がらせてるのは 自分の実力も知らず 相手の実力も知らない そんなお前なんだよ
852 名前:デフォルトの名無しさん mailto:sage [2021/07/25(日) 17:44:55.94 ID:Wj/gwJho.net] >>835 元開発者な方ですか? 効いてるw効いてるw
853 名前:デフォルトの名無しさん mailto:sage [2021/07/25(日) 20:29:47.07 ID:f5YSZ9Lg.net] >>831 gccにはC++に並列ライブラリが入る前からParallel Modeがあって、 今はそこをIntel TBBに丸投げしてるだけだしな 誰かが本格的にテコ入れするまではこのままだろうね
854 名前:デフォルトの名無しさん mailto:sage [2021/07/26(月) 18:54:55.35 ID:poXtKo35.net] GCCはモノリシックにこだわってグチャグチャだし かと思えばHurdはマイクロカーネルにこだわって死産だし あいつらアホなんじゃないかと思うことはある
855 名前:はちみつ餃子 mailto:sage [2021/07/26(月) 20:56:05.01 ID:afAoM3cN.net] GCC はコードの構成が悪いことは百も承知で長期的にソフトウェアの自由を守るために必要だという戦略なんだよ。 当初からの目的通りに活動しているだけ。 まあその戦略で目的をはたせるかどうかは結果を見ないとわからんけどな。
856 名前:デフォルトの名無しさん mailto:sage [2021/07/27(火) 15:50:56.07 ID:P6e91jkT.net] なんで急に書き込み減った? みんなバカンスとってんのか?
857 名前:デフォルトの名無しさん mailto:sage [2021/07/27(火) 16:56:16.02 ID:GsN3P1i6.net] ヒント: じつはこのスレ、大勢いるようで3人ぐらいしかいない
858 名前:デフォルトの名無しさん mailto:sage [2021/07/27(火) 16:59:12.02 ID:/kLodUqV.net] ハノンの書き込みは頭悪いからすぐわかるしな
859 名前:ハノン mailto:sage [2021/07/27(火) 20:34:35.25 ID:RHl6eLWp.net] でも gcc が c での記述を止め、c++ で記述されることになったのには失望しました‥‥
860 名前:ハノン mailto:sage [2021/07/27(火) 20:36:17.62 ID:RHl6eLWp.net] >>842 その「ハノン」という呼び方は本意ではないとピアノスレでも散々力説したのだけれども、とうとう自らハノンと名乗るまでに落ちぶれてしまいまとさ、めでたしめでたし‥‥‥
861 名前:デフォルトの名無しさん mailto:sage [2021/07/27(火) 20:50:38.01 ID:P6e91jkT.net] 同じ奴がたくさん質問してる感じはあるが、回答者はバラバラだと思ってたけどなあ
862 名前:デフォルトの名無しさん mailto:sage [2021/07/27(火) 23:56:35.56 ID:Ke8m4iQ/.net] >>843 コンパイラを走らせる環境はリッチだから問題ない
863 名前:デフォルトの名無しさん mailto:sage [2021/07/28(水) 10:58:41.57 ID:37rNIz61.net] 翻訳環境の怪物化はすごいね
864 名前:デフォルトの名無しさん [2021/07/28(水) 14:40:45.53 ID:JLxqMRcd.net] 組み込み機器も性能があがっているのだから、理屈のうえではC++の導入コストはさがっているとはいえ 不具合が起きた時に全部自分で対応しなければならない苦行から解放されるわけではないから 組み込み系の低レベル開発者がC++を忌避するのは理解できる
865 名前:デフォルトの名無しさん mailto:sage [2021/07/28(水) 15:10:15.29 ID:5zPBGnUX.net] >>841 5ch全体でも5人くらいしか居ないよ。
866 名前:デフォルトの名無しさん mailto:sage [2021/07/28(水) 19:18:33.88 ID:NVIQ8eLn.net] せっかくC++使っているのにイベントバインディングやデリゲートは止めて欲しいな。 クリーンアーキ風から言えばコンストラクターでのディペンデンシーインジェクションにして欲しい。 Cならセルフイベント関数ポインターとコールバックイベント関数ポインターでOKだが、C++ではウザイ。 組込みに生きている身として、最近、富に思う。
867 名前:デフォルトの名無しさん mailto:sage [2021/07/28(水) 20:28:41.06 ID:NVIQ8eLn.net] 連投でスマソ まぁ Ted Faison風のEvent-BasedはC++では終わったという事だわな。 Cでは有効だが、インターフェースの機能があるC++ではレポジトリーの概念が大事という事。
868 名前:デフォルトの名無しさん mailto:sage [2021/07/29(木) 19:38:48.60 ID:N9xjQvrw.net] >>829 返信遅れましたありがとうございます 1. メンバ関数としてbegin()、end()を持つ 2. begin()、end()が間接参照演算子、インクリメント演算子、不等価演算子を持つクラスか構造体を返す という条件を満たすクラスか構造体の範囲for文による走査をopenmpで並列化できたらと思うのですが、何かテクニックないでしょうか
869 名前:ハノン mailto:sage [2021/07/29(木) 20:14:33.88 ID:6W3ohAQ3.net] >>850 組み込みの人が DI を語っておられるとは‥‥
870 名前:デフォルトの名無しさん mailto:sage [2021/07/29(木) 21:38:43.31 ID:teDb7k99.net] またID被ってる
871 名前:デフォルトの名無しさん mailto:sage [2021/07/30(金) 09:02:20.45 ID:7heefpFa.net] ハッシュの衝突くらいで騒ぐかよ
872 名前:デフォルトの名無しさん [2021/07/30(金) 11:20:47.05 ID:+rE3rJXm.net] IPアドレスと日付から算出されるらしいけど結構、衝突するじゃん 体感的にはかなり偏ってて正常なハッシュアルゴリズムとは思えない
873 名前:はちみつ餃子 mailto:sage [2021/07/30(金) 15:01:08.41 ID:qMgk6unv.net] >>856 ハッシュの分散はこの場合は関係ない。 乱数に異常な偏りがある。 これはただの想像だけど、仮想環境の構築にミスがあるんじゃないだろうか。 Docker のスナップショットを作るときに乱数生成器の状態をキャプチャしてしまって 再起動が入ると乱数列も最初から……みたいな。
874 名前:デフォルトの名無しさん mailto:sage [2021/07/30(金) 18:09:27.82 ID:+rE3rJXm.net] >>857 乱数ではないと思うよ なまじ乱数だと、その乱数値を覚えておく保存領域がサーバー上に必要になって手間が増える
875 名前:デフォルトの名無しさん mailto:sage [2021/07/30(金) 19:39:15.89 ID:ftRMaVHk.net] >>856 正常なハッシュアルゴリズムって何? 正常と異常の境界があるの? SHA1は異常なのか?
876 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 05:54:28.89 ID:cWLU96cE.net] 偏りがあったら異常やんけ;;; 例えば0〜LONG_MAXを1バイトにするハッシュ関数が0x1Fを全く出力しないとか、 0〜LONG_MAX/2が全て0x11になるとかだったら>>854 でなくともさすがに違和感をおぼえるであろう、
877 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 07:49:26.34 ID:cWLU96cE.net] ミシュラン2つ星の実力派レストラン「シングルスレッド(Single Thread)」 https://www.foodee.jp/report/restaurant/fusion-cuisine/new-american-cuisine/3338/
878 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 08:09:20.77 ID:t9HNV453.net] >>860 ハッシュと一様乱数を混同してるか?
879 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 10:32:59.95 ID:XdxgF0zQ.net] 結果よりも速度を求められたり、頻出値だけより広く分布させたい場合もあるだろうから要件次第ではあるけども、 一般的には、期待される入力に対して一様に分布していたほうが、衝突確率が下がるのでより望ましい結果と言えるんじゃないの?
880 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 10:52:18.34 ID:o9ang7qv.net] 望ましい、というのは、正常と異常の境ではないな
881 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 11:19:08.67 ID:N/3vvIjJ.net] 最大1000レスまでしか書き込めない同一スレッド上で別人同士がID衝突する確率は宝くじ1等に当たる確率よりも低いと期待できるが、現実はそうなってない
882 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 12:14:03.01 ID:cWLU96cE.net] つくづくボンクラな>>862 、、、 衝突は極力避けたいんだろ? >一様性 >良いハッシュ関数は、考えられる入力範囲が出力範囲全体になるべく一様に分布するようにマッピングを行う。
883 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 12:18:58.07 ID:xfGVog4d.net] 本当にIPアドレスが衝突してる可能性もある 同じマンションとかいう話だけでなくIPoEだと共有してるとかあったはず 技術力なさそうだから5ch側の作りが悪いんだろうけど
884 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 12:23:58.11 ID:t9HNV453.net] >>866 良いとか望ましいなんておまえさんの個人的な主観が聞きたいんじゃねえ ハッシュにおける正常と異常の境界を聞いている 知らないんなら答え(たふりをす)るな
885 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 12:30:10.08 ID:cWLU96cE.net] >>868 って、角度を定規とコンパスで3等分しようとするタイプ?
886 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 12:42:38.84 ID:t9HNV453.net] ここはC++スレだ 人格攻撃は余所でやれ
887 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 12:49:39.86 ID:i9NDIoMF.net] >>868 そんなの設計仕様次第だろ。 SHA1は当初の仕様を満足できない脆弱性を抱えているから、(仕様に対して)異常ということができる。
888 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 13:04:48.82 ID:t9HNV453.net] 弱衝突耐性を破る方法が見つかったか否かが境界というのはおかしいだろ 未発見であることと存在しないと証明されていることは違う
889 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 13:10:19.44 ID:mrismh1j.net] >>872 なんでおかしいのかちゃんと反論しろよ。 SHA1が当初仕様を満足できていないのは間違いなく、仕様を満足できていない以上「(仕様に対して)異常」だろ。
890 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 13:17:04.19 ID:t9HNV453.net] なんでおかしいのか2行目に書いたんだが 話にならない人なのか
891 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 14:14:47.38 ID:N/3vvIjJ.net] >>868 > ハッシュにおける正常と異常の境界を聞いている お金を出す人が境界を決めるだけのこと 技術論の出る幕なし
892 名前:デフォルトの名無しさん [2021/07/31(土) 14:36:13.48 ID:t9HNV453.net] おまえさんが技術論できないのはわかった こちらもこれ以上は追求しない
893 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 14:38:40.17 ID:cWLU96cE.net] >>870 人格攻撃とみなす前に、 入力範囲と出力範囲が同じハッシュ関数において 一様性を満足しないものの衝突耐性が 一様性を満足するものの衝突耐性に勝るケースを一つでも挙げてみたらいかがですかね…… 入力の発生頻度に偏りがありハッシュ関数をそれにチューニングする場合はあり得るが、 入力の発生頻度を限定する話はここまでで出ていないから無いものとして
894 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 14:45:30.93 ID:t9HNV453.net] >>877 ハッシュの正常と異常の境界には関係ない話だな
895 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 14:46:37.30 ID:cWLU96cE.net] >>878 無関係かどうかを論ずるには「正常と異常」の定義を 主観非依存な形で明らかにしていただけませんと、
896 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 14:49:27.72 ID:t9HNV453.net] >>879 それは>>856 に俺が聞いていることだ
897 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 14:52:41.19 ID:cWLU96cE.net] >>856 とかまさにハッシュの一様性の問題でしかないのでは……
898 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 14:57:10.54 ID:t9HNV453.net] 衝突耐性と一様性は関係ない ・・・て、これハッシュの初歩の初歩だぞ
899 名前:はちみつ餃子 mailto:sage [2021/07/31(土) 15:09:12.92 ID:zwQwPVDS.net] >>858 前提として、 ID 生成のおおまかな手順は >>810 のようなものになってる。 使われているハッシュアルゴリズムは古い資料では MD5 ということになっているから、 変更されているとしても MD5 よりは良い性質のものが選ばれていると思う。 ハッシュの衝突が頻繁に起こると考えるよりは生成元のバイト列が同じだったと考えるほうが自然。
900 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 15:14:21.76 ID:wqQpURd2.net] 同一人物の確率が高いですね(・∀・)ニヤニヤ
901 名前:デフォルトの名無しさん [2021/07/31(土) 16:43:06.11 ID:LRA0vGhm.net] 最近は濃度濃いからな
902 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 17:18:39.66 ID:egUJWjj5.net] 左辺値からmove君今日もイキイキしてんな
903 名前:デフォルトの名無しさん mailto:sage [2021/07/31(土) 17:34:47.35 ID:t9HNV453.net] 匿名掲示板で同一人物かどうとかってアホかお前ら
904 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 00:17:38.34 ID:fSdDKS6o.net] >>882 衝突耐性ってのは衝突しても耐えられる性能ってこと? 一様であれば普通は衝突確率自体低くなりそうな気がするけど
905 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 05:57:41.62 ID:4Ph4Dvnc.net] ハッシュの衝突を故意に起こす攻撃への耐性 強衝突耐性と弱衝突耐性がある
906 名前:デフォルトの名無しさん [2021/08/01(日) 11:47:47.11 ID:boMMlR1G.net] >>867 たまたま近所に住んでて出入りしてる店のWiFiが同じとかな
907 名前:デフォルトの名無しさん [2021/08/01(日) 11:50:13.10 ID:boMMlR1G.net] >>877 >入力範囲と出力範囲が同じハッシュ関数 5ch/2ch とは関係無い話をなぜするんだ?
908 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 13:05:26.18 ID:RrS7g+U3.net] >>867 >>890 野良ProxyやNordVPNの様なサービス経由か
909 名前:まあ俺が言うのもなんだがw mailto:sage [2021/08/01(日) 15:28:14.61 ID:BgB9X1kX.net] >>867 クライアントのIP被りと5chサーバーの作りになんの関係が? 技術力ないなら黙ってた方がいいかと
910 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 15:29:14.00 ID:pw89eIDb.net] >>886 レス番で言うと誰が誰?
911 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 17:18:44.88 ID:ebmqBspL.net] >>882 その主張は>>877 の例を挙げられないのなら偽ですなあ〜〜 どんな教科書をどういう読み方してるのか知らんが
912 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 17:20:28.87 ID:ebmqBspL.net] >>888 強衝突耐性 = (>>877 で言うところの)入力範囲 (ハッシュの元になるやつ。5chのハッシュの例でいうと>>810 のデータの集合) からいっぱい集めねば同じハッシュ値(5chの例で言うとID)にならないという特性 (衝突を起こすための仮定が多い(強い条件)から「強」衝突耐性と言うのだと思われ、 弱衝突耐性 = 出力範囲(5chの例で言うとID)から任意に選んだ1つ から入力範囲を再現しにくいという特性 (衝突を起こすための仮定が少ない(弱い条件)から「弱」衝突耐性と言うのだと思われ、 弱衝突耐性が>>856 の問題提起(ID被り)に直接対応する
913 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 17:21:50.37 ID:ebmqBspL.net] ごめ訂正orz 正: 強衝突耐性が>>856 の問題提起(ID被り)に直接対応する で、ハッシュに偏りがあったら、強弱どっちの耐性も一般に低下する >>860 の例でハッシュ関数が0x1Fを出力しなかったら、0〜LONG_MAXからN個ランダムに選んで ハッシュ化したら同じハッシュになる確率が256/(LONG_MAX+1)から255/(LONG_MAX+1)に低下する(弱衝突耐性の劣化 等、 >>886 単発レス君は何か言いたいことがあれば言っても良いのだぞ?匿名掲示板やし……
914 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 17:23:06.81 ID:4Ph4Dvnc.net] >>895 「関係ない」という主張への反駁は 関係あることを示すだけの簡単なことなのに
915 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 17:28:09.09 ID:ebmqBspL.net] >>898 >>897 といっても確率計算をまつがえたのでそこは訂正汁orz、 >>860 の例でハッシュ関数が0x1Fを出力しなかったら、0〜LONG_MAXからN個ランダムに選んで ハッシュ化したら同じハッシュになる確率が 1 - (1-256/(LONG_MAX+1)^N から 1 - (1-255/(LONG_MAX+1)^N に低下し、弱衝突耐性が劣化
916 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 17:51:30.09 ID:4Ph4Dvnc.net] 何で弱衝突耐性に確率が出てくるんだよ
917 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 17:52:27.09 ID:bBrAMy8u.net] ハッシュ関数への入力の時点で衝突してるんだから、MD5だのSHA1だのは関係無い >>810 の時点で指摘されているんだが、いつまでこの無意味な話を続けるつもり?
918 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 18:01:11.28 ID:ebmqBspL.net] >>900 入力範囲のサイズ>>出力範囲のサイズである以上、 全部の入力を考えたら必ず衝突する & 入力範囲(一般に天文学的サイズ)の総当たりは一般遂行不能なので 確率評価するしかないからじゃゃわ;; もちろん、特定の論理的操作で弱点をピンポイントで突けることがわかった場合は ハッシュの衝突耐性の見積もりが確率ではなく論理的に下方修正されるが、そうなった時はそのハッシュが寿命を終えたとき、、、 ガチで基本がわかってない>>900 、、、大丈夫なのか、、、
919 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 18:05:17.08 ID:4Ph4Dvnc.net] > ガチで基本がわかってない 弱衝突耐性とは何かがわかっておらず 正解を書いていながら正解として使えてないやつに 言われたかねえなw
920 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 20:28:45.05 ID:c9gBXIbe.net] >>895 入力バイト列の先頭64バイトを返す「ハッシュ関数」は一様だが衝突耐性は無い 入力バイト列のSHA-256にパディング32バイトを加えて返す「ハッシュ関数」は一様ではないがSHA-256と同レベルの衝突耐性を持つ
921 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 20:57:55.63 ID:jK0t+VIo.net] >>872 >>874 どう考えたら > ハッシュにおける正常と異常の境界を聞いている に対する回答 > そんなの設計仕様次第だろ。SHA1は仕様を満足できないから異常 への反論が > 弱衝突耐性を破る方法が見つかったか否かが境界というのはおかしいだろ > 未発見であることと存在しないと証明されていることは違う になるんだよ。 『設計仕様を正常と異常の境界とすること』と『異常(脆弱性)の不存在証明の有無』は全く関係ない。 SHA1の例でいうと、衝突攻撃の研究によってSHA1の正常・異常の状態が『正常かどうか不明』→『異常』に変化しただけの話で、『境界』と『不存在証明の有無』は矛盾しない。 議論するなら『設計仕様を正常と異常の境界とすること』に対する問題点や矛盾を示せよ。論点ずらしなんかしないで。 あと、>>872 は弱衝突耐性(原像計算困難性)云々言っているが、なんで弱衝突耐性?大本の議論(ID被り)からすりゃ強衝突耐性のほうが重要だし、SHA1で問題になっているのも衝突攻撃に対する脆弱性だろ。SHA1に対する原像攻撃って成功していたっけ? もしかして>>872 は弱衝突耐性と強衝突耐性の違いも知らないでハッシュを語っているのかね? Wikipediaにすら解説が載っているのに。
922 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 21:29:10.73 ID:4Ph4Dvnc.net] ウィキを3時間読んできたのね、ご苦労さん もっと簡単化した文章が書けるように消化してから書いてね 俺、ここでウィキとやりあうつもりはないから # ちな、俺はウィキのとある記事の中の人
923 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 22:09:15.95 ID:DfQPo4se.net] カタカタ || ̄ Λ_Λ ||_(Д`; ) 「なに?このスレ・・・」 \⊂´ ) ( ┳'
924 名前:デフォルトの名無しさん mailto:sage [2021/08/01(日) 22:29:39.30 ID:jK0t+VIo.net] >906 三時間……? なんのこと? なんか幻が見えていない? >905に反応するなんて、もしかして>906は>872 >874だったりするのかね。 弱衝突耐性を理解できていないアホとハッシュの話をしても仕方がないが…… > ちな、俺はウィキのとある記事の中の人 Wikipediaの記事を書いているなら『ウィキ』とかアホな言い方するなよ。 それとも文脈無視して本来の意味の『ウィキ』で使っているのかね。 用語をいい加減に使うヤツは議論や情報共有の邪魔になるゴミ。 Wikipediaで『ウィキ』ぐらい調べてから使えよ。 >907 いつもの楽しい5chのスレです。
925 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 08:57:10.51 ID:59KH06XU.net] 聞きかじったことをリピートしてるだけで 自分なりに熟れてないの見え見えだからw くだらん言葉尻でもいいからと あら探しに必死な姿は恥の上塗りなだけだぜ
926 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 11:14:55.63 ID:6pXxEptq.net] 君もしかして天に唾するクンか?
927 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 11:23:38.63 ID:59KH06XU.net] 弱衝突耐性という用語を使いだしたのは俺だが 「SHA1は仕様を満足できない」と言い出したのはおまえさんだぜ 俺はただ正常と異常の境界は何かと聞いただけ そこへ弱衝突耐性を意味する話をしだしたのがおまえさんだ ここからそもそも頓珍漢なんだがw
928 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 11:38:15.60 ID:zqXMuOMM.net] >911 >872 >874 どう考えたら > ハッシュにおける正常と異常の境界を聞いている に対する回答 > そんなの設計仕様次第だろ。SHA1は仕様を満足できないから異常 への反論 > 弱衝突耐性を破る方法が見つかったか否かが境界というのはおかしいだろ の流れで >そこへ弱衝突耐性を意味する話をしだしたのがおまえさんだ という話になるんですかねぇ。 弱衝突耐性の話を出してきた>872は俺じゃないよ。
929 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 12:23:45.40 ID:59KH06XU.net] いーや弱衝突耐性の出してきたのは>>871 だ 奴は弱衝突耐性という用語を知らなかったようだが 間違いなくその話をしている
930 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 12:25:06.19 ID:pbh5hStk.net] ハノンがコテ隠して発言してて草
931 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 12:42:51.63 ID:pSyuAavC.net] >>913 歴史改竄するなよ。 なんでSHA1の脆弱性の話をしているのに弱衝突耐性の話になるんだよ。 もしかしてSHA1の脆弱性が弱衝突耐性に関するものだと勘違いしている? それなら一連の発言の辻褄が合ってくるけど、まさかね。
932 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 12:45:20.48 ID:59KH06XU.net] >>915 ほうほうw ではSHA1の脆弱性が何だと思ってるんだ、おまえさんは?
933 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 12:56:24.24 ID:pSyuAavC.net] >>916 お前は>>906 でいちゃもんつけている>>905 を読むという誠実さすら無いのか。 バカな上に傲慢とは救いようが無いな。
934 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 13:05:07.60 ID:6pXxEptq.net] 何スレやねん move論争の方がまだマシだったな
935 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 13:28:50.14 ID:59KH06XU.net] >>917 やーい答えらんねえw ブラフまで幼稚とはどこまでも無能なやつだな
936 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 14:17:15.73 ID:knlOee4h.net] ________ | ______ / ̄ ̄ ̄ ̄ ̄ ̄\ | | / ⌒ ー、 :::::::::::U:\ | | /( ○)}liil{( ○) ::::::::::::::| なにこのスレ・・・ | | .|U⌒(__人__) ⌒ ::::::U::::| | | | |r┬-| U...:::::::::::::::::::/ | |____ ヽ `⌒´.....:::::::::::::::::::::::< └___/ ̄ ̄ :::::::::::::::::::::::::| |\ |
937 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 15:45:48.15 ID:59KH06XU.net] ケンカ成分入れたのはこいつ >>866
938 名前:デフォルトの名無しさん [2021/08/02(月) 16:50:20.92 ID:ENgx1DZA.net] 最初にSHA1の話を始めた >>859 が荒れた原因だよ 独りよがりで読解力がないことがたった二行で伝わってくる
939 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 17:03:35.19 ID:ENgx1DZA.net] ダイジェスト長約48bit相当しかない5chのIDをなぜかダイジェスト長160bitのSHA1に関連付けて語りだしたアホがすべての原因
940 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 17:07:16.03 ID:ENgx1DZA.net] 宝くじ一等当選確率を1千万分の1とすると、log(10000000)/log(2) = 23.253496664... つまりダイジェスト長は約23bitに相当する
941 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 18:28:05.17 ID:J7wQxpF0.net] >>919 あらら、幼児退行したか。 議論もレスバも意味ないな。相手にするだけ無駄か。 ロクに調べずに、SHA1の脆弱性の話で弱衝突耐性とか言い始める無能だからなぁ。 とりあえず>>919 はコテハン付けとけ。NG設定するから。
942 名前:デフォルトの名無しさん [2021/08/02(月) 18:57:52.80 ID:gLOyL8sZ.net] あわしろ氏は、そうは言ってなかったな。
943 名前:ハノン mailto:sage [2021/08/02(月) 19:53:00.83 ID:cVX0s0Vd.net] >>914 わたしじゃないですよ!あとハノン呼ばわりは本意じゃないから止めて!
944 名前:デフォルトの名無しさん mailto:sage [2021/08/02(月) 21:26:49.50 ID:flJzbmIi.net] 名乗っておいて呼ぶなとは一体…
945 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 00:20:17.34 ID:oJ5wTgbl.net] 質問です クラス型の変数を関数内で宣言してreturnする関数があって、別の関数からクラス型の変数の宣言と同時にその関数呼び出したときに、moveコンストラクタをdeleteしてるとコンパイルエラーになるのでmoveしてると思いますが、moveコンストラクタを自前で作ってprintfしてても何も出力されないのはどうゆうことですか?
946 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 00:45:04.37 ID:WMUswgP6.net] それは近年話題沸騰中のNRVO・ムーヴ省略でございます
947 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 00:47:12.42 ID:9z5WCbe9.net]
948 名前:move constructorをdeleteすると自動的にcopy constructorも deleteされるからコンパイルエラーになるのでは [] [ここ壊れてます]
949 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 07:24:04.62 ID:wbx4PwZT.net] >>922 SHA1とは言ったが脆弱性とは言ってない まんまと思う壺にハマって地団駄踏んでももう遅いんだよw
950 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 08:13:23.67 ID:51l84/HQ.net] >>932 コテハン付けろよ。
951 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 08:19:20.45 ID:wbx4PwZT.net] やだね 匿名掲示板をらしく使うのさ
952 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 08:21:29.28 ID:oNdzKEkg.net] お、おう
953 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 11:04:05.90 ID:VqTXxKXQ.net] >>930 ムーヴ省略ではないでしょ
954 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 11:10:04.38 ID:WMUswgP6.net] >>936 寝ぼけてましたすんません >>937 が正しいですね
955 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 11:10:55.96 ID:WMUswgP6.net] >>937 →>>931 もうだめだ
956 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 12:43:15.32 ID:oNdzKEkg.net] >>938 オキロ
957 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 13:37:49.45 ID:gDGs5ymT.net] >>931 初めて知りました。ありがとうございます その線で試してみます
958 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 22:48:49.67 ID:OOW3UK0A.net] >>929 の者です 何もしてないときはNRVO、 move constructorをdeleteしたときはcopy constructorが暗黙定義されずコンパイルエラー、 move constructorを自分で書いたときはcopy constructorが暗黙定義され呼ばれる となっていたようです NRVOという機能があることも知らず勉強になりました ありがとうございました
959 名前:デフォルトの名無しさん mailto:sage [2021/08/03(火) 23:08:06.61 ID:OOW3UK0A.net] >>941 すみません、もう一回ちゃんと見てみたらcopy constructorは全く関係なかったです move constructorがあればRVO/NRVOが働き、deleteすれば削除された関数を参照しようとしていますとなってコンパイルエラーでした
960 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 00:25:17.82 ID:+cdzf+J+.net] begin と end ってどう実装すりゃ良いのか分からんのだが イテレータの方で「beginイテレータ」と「endイテレータ」みたいなものを実装しておいて begin と end はそれを呼ぶだけにするのってアリ? あるいは、イテレータの初期値が begin 相当の場所を指すようにしておいて、イテレータの方で + 演算子を実装しておいて、 begin は初期化されたイテレータを、end は初期化されたイテレータ+Nを返すようにするもの? ただし N はそのクラスのサイズみたいなものとする
961 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 03:50:58.62 ID:ZVqKoTKv.net] >>943 具体的な懸念が無いなら好きに試してみろとしか言えないかな。
962 名前:デフォルトの名無しさん [2021/08/06(金) 07:46:08.96 ID:QuhZpDl4.net] >>943 特に詳しく無いんだけど(レベル低い話してたらごめんなさい)。 自分書いた時は、自分でこさえたコンテナクラス内にclass my_iterator を定義して、 必要な typedef (difference_typeなど)を行って(これやらんとアルゴリズムによっ てはあれが無いとか文句言いよる)、あとは、いくつかの演算子を定義した。 イテレータの演算子は * ++ != あたりは定義したかな?足りなかったら追加の方向。 begin() end() は、my_iterator構築時にをポインタやインデックスなどの情報食わ せて、そのオブジェクトを返す。 auto p = myobj.begin(), e = myobj.end(); while(p != e) { *p = ...; ++p; } const に対応したり、後ろから反対向きにすすむ iterator とか、個別に定義して いくとなんかかったるい。頑張って定義しても1回しかつかってねーよ的な。 自分は組み込みで書くことが多いんで、移植性の問題で標準ライブラリの利用も ごく限定的なんで、劣化再発明でなんとかしないといけないことが多いから、 たまに必要になるんだけど。
963 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 08:00:58.65 ID:QgUKHcUo.net] 逆進反復子はstd::reverse_iteratorで合成できるやん
964 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 11:23:00.02 ID:ejThTeu5.net] 演算子や反復子のオーバーロードはその性質上、オーバーロード箇所を見つけにくくなる副作用が大きくて使うの避けてるわ ラムダ式は、たとえメモ帳で開いた場合でも視認性は落ちないからこの種の副作用はない
965 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 11:28:33.23 ID:QgUKHcUo.net] 反復子は仮引数を持たないから多重定義できない
966 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 12:40:53.32 ID:K8ga5O1Z.net] >>945 レベル低いっつーか聞かれてもない当たり前のことを長く言っている
967 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 13:39:39.31 ID:ACcOU+tV.net] operator* != ++(前置)を持ってるオレオレイテレータとそれを返すbegin()とend()が揃ってれば 拡張for文で使えるから大抵はそれで十分
968 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 13:45:20.78 ID:61Kw3Trn.net] iterator_traitsも使わんのか 最近の小わっぱどもわ
969 名前:はちみつ餃子 mailto:sage [2021/08/06(金) 14:06:55.11 ID:hvfblY74.net] イテレータのカテゴリ (ランダムアクセス、双方向、片方向) によるが、 イテレータとして求められる要件は (C++11 だと) 24.2 にまとめられている。 https://timsong-cpp.github.io/cppwp/n3337/iterator.requirements requirements はあくまでも標準においてはこういう前提を置いているという話なんで、 標準ライブラリとの組み合わせを考えなくていいなら厳密に従う必要はない。 組み込み系とかではどうせ標準ライブラリのフルセットなんか提供されないってことも多いだろうし。
970 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 14:25:41.28 ID:UG3EYJ5j.net] >>943 上のやり方と下のやり方でどっちが良いか決めるなら、当然下のやり方だろう
971 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 15:02:59.98 ID:UG3EYJ5j.net] >>943 ,953 補足 前者はそもそも意味がよーわからん
972 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 20:55:48.69 ID:51YKCZf/.net] だれかSOLID原則わかりやすく教えて
973 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 21:09:37.01 ID:2iK9+WXa.net] Dは重要
974 名前:デフォルトの名無しさん mailto:sage [2021/08/06(金) 21:15:50.18 ID:51YKCZf/.net] 依存性逆転… メンヘラに逆に依存しろってこと?
975 名前:デフォルトの名無しさん mailto:sage [2021/08/07(土) 21:57:40.18 ID:fhvRgHLH.net] OSAL(Operating system abstraction layer)について教えてくだちい 正しいAPI仕様はどこ見たら良いの? ぶっちゃけスレッドの生成とJOIN、クリティカルセクション、イベント通知手段、セマフォ、遅延(Sleep) が使えれば良いぐらいのミニマルな要求なので自力実装しても良いが方言を増やしても仕方が無いし、
976 名前:デフォルトの名無しさん mailto:sage [2021/08/07(土) 22:19:39.31 ID:htSYk34i.net] std::threadつかうかpthread使えば。
977 名前:デフォルトの名無しさん mailto:sage [2021/08/07(土) 22:28:21.15 ID:P3NgS3ss.net] これじゃないの?知らんけど ttps://github.com/nasa/cFS/blob/gh-pages/OSAL_Users_Guide.pdf
978 名前:デフォルトの名無しさん [2021/08/07(土) 22:38:16.24 ID:dRA6eDJQ.net] お猿って読むのかな?
979 名前:デフォルトの名無しさん mailto:sage [2021/08/07(土) 23:51:20.36 ID:fhvRgHLH.net] >pthread 質問しておいてアレですが確かにOSの抽象化はPOSIXじゃいかんのか、とは思いました ただpthread関連は使いにくいすぐる…… Win32APIでpthreadの互換品を作る事態になったら何のために生きているのかわからなくなりそう……
980 名前:デフォルトの名無しさん mailto:sage [2021/08/07(土) 23:59:07.20 ID:tg14s6ns.net] 使いにくいって 学習しろよバカが
981 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 03:38:56.69 ID:o6Sz00kX.net] RTOS向けのAPIらしいねOSAL そういう用途で重要な要件を満たせるような仕様になってるのだろう知らんけど
982 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 05:12:10.85 ID:b7/SG9Fy.net] どちらかというとコードの動きが詠めずにコンパイルエラーに頼りまくるバカの方が大問題な気がする
983 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 09:36:28.23 ID:FX9juWvg.net] コードの動きを、詠む 風流だな
984 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 09:54:35.44 ID:X9nZYb13.net] std::threadを使わない理由を説明してもらわんとアドバイスのしようがないね
985 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 11:10:29.77 ID:p8p3x866.net] コードはアートだぞ?
986 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 11:17:36.30 ID:qvupnXSA.net] コードアートオンライン
987 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 13:32:41.01 ID:GYDyEW6S.net] プラットフォームごとにスレッド関数がまちまちなことは大した問題じゃないんだが、スレッド同期を考えればstd名前空間のクラスを使うのが今後の最適解になるでしょ
988 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 14:23:53.13 ID:tnUFWQWl.net] コンパイラや標準ライブラリの製作者よりも俺の方が詳しいと確信できる時以外は素直にstdに甘えるべき
989 名前:デフォルトの名無しさん [2021/08/08(日) 15:36:10.77 ID:Hwfa9w/d.net] int a[3] = {1, 2, 3}; for(auto&& b : a) { std::cout << b; } この範囲for文の「&&」って何者なの? 参照? autoもautoで、autoはC++11で廃止になったって聞いてたんだけど・・・
990 名前:はちみつ餃子 mailto:sage [2021/08/08(日) 15:50:15.52 ID:3b5W4SC5.net] >>972 auto は C から引き継いで C++ にも以前からあったキーワードだけれど、 誰も使ってなかったから元の意味を廃止してあらたな意味で使われるようになった。 廃止されたのは auto の以前の使い方であってキーワード自体は廃止されてない。
991 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 16:04:41.80 ID:b7/SG9Fy.net] 値の参照値変数を伴ない値参照とでもいうべきか
992 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 16:06:14.93 ID:tnUFWQWl.net] 釣りじゃないなら、とりあえず右辺値参照でググって一通り読んでこい ここで全部説明してると長すぎる
993 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 16:07:11.93 ID:b7/SG9Fy.net] forループとかココらへんはコンパイラの最適化によっては&参照とあんま変わらんよな
994 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 16:15:05.55 ID:o6Sz00kX.net] auto && に関しては右辺値参照とは限らないというのもまたややこしい
995 名前:はちみつ餃子 mailto:sage [2021/08/08(日) 16:16:14.37 ID:3b5W4SC5.net] >>972 && は普通は右辺値参照を意味するが、一部の状況では万能参照になる。 (言語仕様上は万能参照とは呼ばれないが通例としてそう呼ぶことが多い。) 初期化子によって左辺値参照か右辺値参照かを自動的に選択するので、 よく理解できてないなら範囲for文をつかうときは && にしておけと入門者に勧める解説はよく見る。 実際、その状況では auto& と書いても結果は変わらない。
996 名前:デフォルトの名無しさん [2021/08/08(日) 16:53:04.10 ID:Hwfa9w/d.net] >>973 >>978 ありがとう・・・! メモっとく
997 名前:はちみつ餃子 mailto:sage [2021/08/08(日) 17:22:47.83 ID:3b5W4SC5.net] >>979 言葉の様子からは昔の C++ (C++03 以前) は使ってたのかな? と推察するけど、 C++03 と C++11 の間では大きな飛躍があって、 その後も変更は色々あるのでちょっとしたことをいちいち質問するのは効率悪いと思う。 ドキュメントを網羅的にわかりやすく整理しているとてもありがたいサイトがいくつかあって 仕様改定がどういうものだったのかもまとまっているので参考にするといいよ。 https://cpprefjp.github.io/lang/cpp11.html https://ja.cppreference.com/w/cpp/11
998 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 19:31:37.38 ID:R0ImpkBa.net] std::threadってなぜかスレッドが実行中かどうかを調べるだけの関数がないんだよね 絶対にあった方が良いと思うんだけどなんか理由があるのかな
999 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 19:40:44.42 ID:Cdmlpdjr.net] joinableだけじゃ足りん?
1000 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 19:45:39.50 ID:8fWNQyKy.net] pthreadsにそういうAPIが無いからなぁ
1001 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 19:55:15.31 ID:GYDyEW6S.net] pthread_timedjoin_np()使えばいいじゃない
1002 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 20:02:19.74 ID:8fWNQyKy.net] none portableじゃないですかやーだー (でも使う) 標準としては難しそう
1003 名前:蟻人間 mailto:sage [2021/08/08(日) 20:27:26.52 ID:7BKdY7dG.net] native handleをgetしてWaitForSingleObject使うとか
1004 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 20:52:17.07 ID:GYDyEW6S.net] >>985 nandemo portable の略だから大丈夫
1005 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 21:39:14.34 ID:yBkpHZYz.net] 普通にミューテックスで排他して状態管理せよ…… だいたいスレッドが動いているかどうかという1 bitだけを外部が欲しがるという用途は(join操作そのものを除き)あんま無く、 キュー的なブツに対するデータの排他的な出し入れが普通伴うはず……
1006 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 21:44:02.93 ID:yBkpHZYz.net] ミューテックスで数千クロックサイクル浪費するのが嫌という向きは知らん スピンロックとかdouble-checking lockみたいな対策になるかと思うが絶対安全かつポータブルな 方法というものは無くなる希ガス
1007 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 22:18:09.18 ID:GYDyEW6S.net] >>988 速度重視でmap/unordered_mapでコンテナ作ってみたけどやっぱり仕様変更に耐えられるvector/listコンテナ最強的なオチに似たものある
1008 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 22:43:58.32 ID:8fWNQyKy.net] キューへの投入と取り出しがそれぞれ1スレッドだけならミューテックスを使わなくてもアトミック変数だけで排他出来る(OSに仲裁してもらわなくていい)
1009 名前:デフォルトの名無しさん mailto:sage [2021/08/08(日) 23:27:24.23 ID:yBkpHZYz.net] OSの助けなしにどうやって待ち(と起床)を実現するつもりなんじゃ……
1010 名前:デフォルトの名無しさん [2021/08/08(日) 23:43:25.11 ID:2XV4yDHI.net] スレッドが実行中か確認したいってどんなときなのかな? 確認したところで次の瞬間には終了してる可能性あるわけじゃん 終了を待機したいならjoinすればいいし実行中をなんのために確認したいのかよくわからん
1011 名前:デフォルトの名無しさん mailto:sage [2021/08/09(月) 00:16:27.81 ID:bkD+cive.net] Linuxのpthread_mutexの実装で使われているfutexも競合しないタイミングならユーザランドだけで処理が完結する (OSが仲裁する必要があるのは競合する場合だけ) > Futex operation occurs entirely in user space for the > noncontended case. The kernel is involved only to arbitrate the > contended case. As any sane design will strive for > noncontention, futexes are also optimized for this situation. > > https://man7.org/linux/man-pages/man7/futex.7.html キューが固定長, 投入スレッド1つ, 取り出しスレッド1つという条件でならアトミック変数2つ(読み出し位置, 書き込み位置)で「競合しない」ように出来るので, OSの仲裁が必要じゃなくなる
1012 名前:デフォルトの名無しさん mailto:sage [2021/08/09(月) 00:22:59.44 ID:bkD+cive.net] あと(pthread_mutexのようなネイティブの)mutexはそういう理由で大抵の場合は最速のロック機構になっているので, 自分で作るなら普通にmutex使った方がいいというのは同意 素人(俺とか)の考えたロックフリーデータ構造とか大抵設計か実装かその両方でバグが入る
1013 名前:デフォルトの名無しさん mailto:sage [2021/08/09(月) 07:54:40.07 ID:eF2Q2UUf.net] >>989 mutexが遅くてイヤならatomicじゃね?
1014 名前:デフォルトの名無しさん mailto:sage [2021/08/09(月) 09:47:15.53 ID:TRAo/ccI.net] >スレッドが実行中か確認したいってどんなときなのかな? 排他制御付きのキューを自力実装するときまれによくある…… キューがあふれそうになったときpushする側(producer)を待たせる作りにした場合、 popする側(consumer)はデータをpop後、producerが待っていたらその待ちを解除、 待っていなかったら何もしないという判断が居るのでこのためのフラグ (producer側にpushを継続する意思があるかどうか、またはpush待ち中かどうかを表すフラグ)が居る producerよりconsumerがいつも速い見込みでキューがあふれない前提(キューが必要に応じていくらでも大きくなる) だったりその他(待ち解除が条件変数ではなくキューイングされるイベントだったり)だと無くてもよいから ぜってー必要か、というとビミョーだがあった方がすっきり効率的なコードとして書ける
1015 名前:デフォルトの名無しさん mailto:sage [2021/08/09(月) 09:51:30.16 ID:TRAo/ccI.net] >>996 インターロックドインクリメントはまれによく使う インクリメントに性交したら排他的操作権を獲得できた証、
1016 名前:デフォルトの名無しさん mailto:sage [2021/08/09(月) 09:55:16.95 ID:TRAo/ccI.net] となるようにインクリメントするカウンタの意味を仕向ける
1017 名前:デフォルトの名無しさん mailto:sage [2021/08/09(月) 09:55:21.66 ID:eF2Q2UUf.net] >>998 アンカーミスってねい?
1018 名前:1001 [Over 1000 Thread.net] このスレッドは1000を超えました。 新しいスレッドを立ててください。 life time: 81日 23時間 0分 8秒
1019 名前:過去ログ ★ [[過去ログ]] ■ このスレッドは過去ログ倉庫に格納されています