※前スレ
C++相談室 part154
https://mevius.5ch.net/test/read.cgi/tech/1610096040/
テンプレここまで
探検
C++相談室 part155
■ このスレッドは過去ログ倉庫に格納されています
2021/03/24(水) 12:07:15.39ID:R+oM8cup
286デフォルトの名無しさん
2021/04/20(火) 12:36:36.65ID:q1a39yZP287デフォルトの名無しさん
2021/04/20(火) 12:42:32.22ID:VIg6RvGl >>286
そこ区別して同僚の愚痴を先輩の愚痴に書き換えたところでなにも変わらんだろアホ
そこ区別して同僚の愚痴を先輩の愚痴に書き換えたところでなにも変わらんだろアホ
288デフォルトの名無しさん
2021/04/20(火) 12:43:21.01ID:X7tfUSAH 技術的な話で太刀打ちできなさそうだと枝葉末節で揚げ足取りが始まる掲示板はどこでしょう?
そう、ここです!
そう、ここです!
289デフォルトの名無しさん
2021/04/20(火) 12:43:25.81ID:foxJ/HUw290デフォルトの名無しさん
2021/04/20(火) 13:00:09.50ID:xhmy6KmQ291デフォルトの名無しさん
2021/04/20(火) 13:46:48.72ID:NNyYGUS8292デフォルトの名無しさん
2021/04/20(火) 13:47:04.64ID:9UAiU1Oe293デフォルトの名無しさん
2021/04/20(火) 14:16:30.60ID:fd+AEuq4 C++11以降はそれ以前のC++とまるで別の言語のような感さえある。
だが基本中の基本である文字列操作がJavaやPythonほど簡単になってないのが残念。
だが基本中の基本である文字列操作がJavaやPythonほど簡単になってないのが残念。
294デフォルトの名無しさん
2021/04/20(火) 15:06:35.17ID:VvQCOD1T295デフォルトの名無しさん
2021/04/20(火) 15:35:17.43ID:9UAiU1Oe linuxでopenglやりたいので、c++かなと。
296デフォルトの名無しさん
2021/04/20(火) 20:37:50.18ID:Pk69v7H3297デフォルトの名無しさん
2021/04/20(火) 20:42:34.03ID:NN6yC6GV しったか乙
298デフォルトの名無しさん
2021/04/20(火) 20:55:33.24ID:Pk69v7H3 まあどの道64ビットに収まる桁数だったら意味ないってことは上で結論出てるけどな
299デフォルトの名無しさん
2021/04/20(火) 21:01:48.70ID:YUL53Jgh 掲示したソースコードにおける
最適化に対するメモリエリアシングの影響について:
最適化に対するメモリエリアシングの影響について:
300デフォルトの名無しさん
2021/04/20(火) 21:25:08.48ID:odq3qVNb クラスに特定のoperatorが定義されているか調べるために、
以下のようなtemplateを作ってMSVCでもclangでも一応期待通りに動いてはいるんだが、
VS2019のintelliSenseの解析が異常終了するらしく機能しなくなるんだよね、VS2017は大丈夫なんだけども
何か変かな?
template < typename OPERATOR, typename T > class has_operator
{
private:
template < typename U > static auto check(U x) -> decltype(x.operator OPERATOR(), std::true_type());
static std::false_type check(...);
public:
static bool const value = decltype(check(std::declval<T>()))::value;
};
以下のようなtemplateを作ってMSVCでもclangでも一応期待通りに動いてはいるんだが、
VS2019のintelliSenseの解析が異常終了するらしく機能しなくなるんだよね、VS2017は大丈夫なんだけども
何か変かな?
template < typename OPERATOR, typename T > class has_operator
{
private:
template < typename U > static auto check(U x) -> decltype(x.operator OPERATOR(), std::true_type());
static std::false_type check(...);
public:
static bool const value = decltype(check(std::declval<T>()))::value;
};
>>284
>Karatsuba法推しの香具師はいっぺん自力で実装してみたらいいかもしんない
わたしも、やろう、やろう、とおもってても最後は「この野郎」になってしまうのです
カラツバ、今の私には強敵です…
>Karatsuba法推しの香具師はいっぺん自力で実装してみたらいいかもしんない
わたしも、やろう、やろう、とおもってても最後は「この野郎」になってしまうのです
カラツバ、今の私には強敵です…
302デフォルトの名無しさん
2021/04/20(火) 22:33:18.23ID:nuXnJUWD 桁数nとしてカラツバはおよそnの1.6乗でFFTならnlognなのになぜか皆カラツバの方をチョイスしててワロ
文系の皆さんにはフーリエ変換なんて難し過ぎるか
文系の皆さんにはフーリエ変換なんて難し過ぎるか
303デフォルトの名無しさん
2021/04/20(火) 22:35:49.17ID:nuXnJUWD FFTの方は奥村のCアルゴリズム本に載ってるからアクセスしやすいけどね
カラツバはクヌース本くらいしか知らん
カラツバはクヌース本くらいしか知らん
305デフォルトの名無しさん
2021/04/21(水) 06:19:59.72ID:Y7fj3JnX QZは高卒だったのか
306デフォルトの名無しさん
2021/04/21(水) 09:14:33.98ID:d8/E1L9C307デフォルトの名無しさん
2021/04/21(水) 10:43:52.09ID:NcgxI3iC 高卒・・・そんなんで偉そうに留数定理とかのたまってたのか
308デフォルトの名無しさん
2021/04/21(水) 10:46:51.63ID:T8R/7AcW 複素数に関するアレコレが指導要領に入ってた頃の高卒だと思うと逆に悲しいな笑
309デフォルトの名無しさん
2021/04/21(水) 10:52:21.72ID:NcgxI3iC いや高校では複素解析やらんだろ・・
310デフォルトの名無しさん
2021/04/21(水) 10:55:55.53ID:d8/E1L9C 誘導してんだからあっち行けよ
311デフォルトの名無しさん
2021/04/21(水) 11:11:39.04ID:DSKXDkbA312デフォルトの名無しさん
2021/04/21(水) 11:15:29.03ID:bCpwaxws313デフォルトの名無しさん
2021/04/21(水) 11:23:22.29ID:DSKXDkbA314デフォルトの名無しさん
2021/04/21(水) 11:37:50.39ID:f6qdR5OJ QZを批判すると必ず現れるD:DSKXDkbAみたいな奴
怪しい
同一人物だろうな
QZは>>304と同じIDで書き込みしてみろよ
無理だろうがなw
それに多価関数がわからないと泣いていたよなQZww
哀れ過ぎる
怪しい
同一人物だろうな
QZは>>304と同じIDで書き込みしてみろよ
無理だろうがなw
それに多価関数がわからないと泣いていたよなQZww
哀れ過ぎる
315デフォルトの名無しさん
2021/04/21(水) 11:43:42.91ID:T8R/7AcW >>304は昨日なので、同じIDが出せたらモノホンのハッカーでは
316デフォルトの名無しさん
2021/04/21(水) 11:45:25.27ID:f6qdR5OJ なるほど
昨日だから今日これだけ暴れているのか
なおさら哀れになってくる
実際の自分より良く見せようとする病気=自己愛性パーソナリティ障害
昨日だから今日これだけ暴れているのか
なおさら哀れになってくる
実際の自分より良く見せようとする病気=自己愛性パーソナリティ障害
317デフォルトの名無しさん
2021/04/21(水) 12:05:54.31ID:tWbCEelV 技術系の板に精神分析を書き込む人って、その人自身が精神を病んだ経験ありそう
鏡に話しかけてる感じ
お大事に
鏡に話しかけてる感じ
お大事に
318デフォルトの名無しさん
2021/04/21(水) 12:17:39.89ID:v7jA28gl319デフォルトの名無しさん
2021/04/21(水) 12:17:53.81ID:ysdTsnNz320デフォルトの名無しさん
2021/04/21(水) 12:18:17.72ID:S0SCN4KK 言語規格厨のウザさは以上
コピー代入が、ムーブ代入がってそんなことより
さっさと仕事しろよ
工数足りないんだよ
コピー代入が、ムーブ代入がってそんなことより
さっさと仕事しろよ
工数足りないんだよ
321デフォルトの名無しさん
2021/04/21(水) 13:43:53.29ID:iJBMse6c それマ板向きの話題
煽りとかでなくわりとまじで
煽りとかでなくわりとまじで
322デフォルトの名無しさん
2021/04/21(水) 16:19:12.57ID:Xwi7hGL+323デフォルトの名無しさん
2021/04/21(水) 16:40:24.72ID:d8/E1L9C どうせならエトルフィン出してもらえよ
324デフォルトの名無しさん
2021/04/21(水) 16:49:56.10ID:tWbCEelV な、自作自演で同一人物が書き込んでいると思い込んでるだろ?
やたらと薬物(合法)の名前に詳しいだろ
この辺が病んでいる・病んでいた証拠なんだよ
やたらと薬物(合法)の名前に詳しいだろ
この辺が病んでいる・病んでいた証拠なんだよ
326デフォルトの名無しさん
2021/04/21(水) 17:11:51.30ID:BQWVCdUr 薬の名前はQZが自分で書いてたんだぞ
http://peace.2ch.net/test/read.cgi/tech/1313183984/303
>303 名前: ◆QZaw55cn4c [] 投稿日:2012/07/28(土) 18:08:51.36
>>>302
>飲んでるお薬 http://upload.wikimedia.org/wikipedia/commons/c/c2/Thorazine_advert.jpg
http://peace.2ch.net/test/read.cgi/tech/1313183984/303
>303 名前: ◆QZaw55cn4c [] 投稿日:2012/07/28(土) 18:08:51.36
>>>302
>飲んでるお薬 http://upload.wikimedia.org/wikipedia/commons/c/c2/Thorazine_advert.jpg
327デフォルトの名無しさん
2021/04/21(水) 17:57:01.32ID:d8/E1L9C328デフォルトの名無しさん
2021/04/21(水) 19:51:15.95ID:Y7fj3JnX どうでもいい
329デフォルトの名無しさん
2021/04/21(水) 19:58:40.75ID:2oKQsBoE >>284のKaratuba法のコードには計算結果に影響するバグがあった(爆
修正したやつを貼る、
https://ideone.com/mhRQte
バグとしては、>>284のままでは次の計算を誤る。
0xffffffffffffffffに対し0x0000000100000001を乗算
Num in hexa: 0xFFFFFFFEFFFFFFFF <== BUG!
Expected: 0x100000000FFFFFFFEFFFFFFFF
げいいんは、Karatuba法であるmul_mlen_mlen()の末尾で
z2 * 2^(b+1) + z0 に対し、z1 * 2^bを加算する
という演算をやっているのですだが、桁上がりをきちんと2^(b+2)のワードまで
伝えていなかった、|||。n_
あと細かい点として、符号反転を0に対して無駄に行う個所があったのでそこも修正すた、
カナーリ切羽詰まってきているのでレスはあとでまとめて読みませていただきまつ以下略、
修正したやつを貼る、
https://ideone.com/mhRQte
バグとしては、>>284のままでは次の計算を誤る。
0xffffffffffffffffに対し0x0000000100000001を乗算
Num in hexa: 0xFFFFFFFEFFFFFFFF <== BUG!
Expected: 0x100000000FFFFFFFEFFFFFFFF
げいいんは、Karatuba法であるmul_mlen_mlen()の末尾で
z2 * 2^(b+1) + z0 に対し、z1 * 2^bを加算する
という演算をやっているのですだが、桁上がりをきちんと2^(b+2)のワードまで
伝えていなかった、|||。n_
あと細かい点として、符号反転を0に対して無駄に行う個所があったのでそこも修正すた、
カナーリ切羽詰まってきているのでレスはあとでまとめて読みませていただきまつ以下略、
330デフォルトの名無しさん
2021/04/21(水) 20:01:20.31ID:9Ni9X3TR げいいん
331デフォルトの名無しさん
2021/04/21(水) 20:20:55.73ID:Y7fj3JnX ダサ
332デフォルトの名無しさん
2021/04/21(水) 20:22:03.31ID:tWbCEelV 🍺🐋鯨飲🐳
C++と関係ない話ばっかりだな
C++と関係ない話ばっかりだな
333デフォルトの名無しさん
2021/04/22(木) 00:17:13.55ID:ru2ShUiK334デフォルトの名無しさん
2021/04/22(木) 06:53:49.94ID:WQGVMWvQ mul_mlen_mlen()自体は桁数がスゲー長いケース(任意長)に対応していることは読めばワカル
Wrapperであるmul_u64_64()が128 ビットでそれを使っているというだけ
Wrapperであるmul_u64_64()が128 ビットでそれを使っているというだけ
335デフォルトの名無しさん
2021/04/22(木) 06:58:17.03ID:HV6xjPl7 いや、カラツバなんか実装する意味ねえつってるんだがどこまで馬鹿なんだ
336デフォルトの名無しさん
2021/04/22(木) 07:17:22.47ID:WQGVMWvQ337デフォルトの名無しさん
2021/04/22(木) 07:32:14.23ID:/jtf723l だめだこりゃ
338デフォルトの名無しさん
2021/04/22(木) 08:16:22.82ID:wJAS8IOG 桁数がスゲー長いケースならカラツバなんか使わんし
数倍長程度でも使わん
もちろん速度やリソースを無視して単に動くって意味なら何でも良い好きにしろ
数倍長程度でも使わん
もちろん速度やリソースを無視して単に動くって意味なら何でも良い好きにしろ
339デフォルトの名無しさん
2021/04/22(木) 10:16:28.69ID:yNSfYish long longで足りんとき俺はgmp使う
340デフォルトの名無しさん
2021/04/22(木) 11:19:45.75ID:ZUdmCczU おれはlong long long使う
341デフォルトの名無しさん
2021/04/22(木) 11:45:41.25ID:lbVcz3R2342デフォルトの名無しさん
2021/04/22(木) 11:45:53.93ID:aclQQfDP お前らlong long long long使えるのしらねーの?
343デフォルトの名無しさん
2021/04/22(木) 12:22:51.68ID:ZUdmCczU 精度、用途、環境
で色々な方法を使うのがベスト
カラツバだけ知っててもほとんど役に立たない
下位レイヤーでもFFT, double-double, ...
など色んな方法があるし
上位レイヤーから下位レイヤーまで全体を考えて最適化しないとダメ
で色々な方法を使うのがベスト
カラツバだけ知っててもほとんど役に立たない
下位レイヤーでもFFT, double-double, ...
など色んな方法があるし
上位レイヤーから下位レイヤーまで全体を考えて最適化しないとダメ
344デフォルトの名無しさん
2021/04/22(木) 12:23:45.87ID:7u43wDLB boostって使える?
あれって、単なるテンプレートで遊んでるだけだろ
そのくせにやたら遅い
正直使い物にならないイメージ
あれって、単なるテンプレートで遊んでるだけだろ
そのくせにやたら遅い
正直使い物にならないイメージ
345デフォルトの名無しさん
2021/04/22(木) 12:31:27.85ID:EICaHt7b >>226でいいじゃん。
これ以上早くしたかったらどうせ環境依存になる
これ以上早くしたかったらどうせ環境依存になる
346デフォルトの名無しさん
2021/04/22(木) 12:43:04.70ID:PcdMDerm347デフォルトの名無しさん
2021/04/22(木) 12:44:09.02ID:b8cAf5Rb >>344
使えるかどうかは置いといて、遅いのは最適化が効いてないとかでは?
使えるかどうかは置いといて、遅いのは最適化が効いてないとかでは?
348デフォルトの名無しさん
2021/04/22(木) 13:00:03.48ID:7u43wDLB >>347
formatなんて激遅
formatなんて激遅
349デフォルトの名無しさん
2021/04/22(木) 13:10:24.41ID:EICaHt7b >>344
boostは標準ライブラリとして採用するための実験場的な側面があるから、C++11以降を使っているならboostに足を向けて寝ちゃだめよ
boostは標準ライブラリとして採用するための実験場的な側面があるから、C++11以降を使っているならboostに足を向けて寝ちゃだめよ
350デフォルトの名無しさん
2021/04/22(木) 17:00:53.68ID:j9DIDz/e stlもコンテナ類からして設計哲学に問題あると思ってる。
それにsize_tがunsignedで、ssize_tがsignedなのも馬鹿。
伝統的なCでは、strlen()などはintでsignedだったのだから、
短く書ける方のsize_tを最初からsignedにすべきだった。
それにsize_tがunsignedで、ssize_tがsignedなのも馬鹿。
伝統的なCでは、strlen()などはintでsignedだったのだから、
短く書ける方のsize_tを最初からsignedにすべきだった。
351デフォルトの名無しさん
2021/04/22(木) 17:06:31.92ID:j9DIDz/e 伝統的なCでは、
int strlen( const char *str );
だったのが、なぜか、64BITにも対応した後は、
size_t strlen( const char *str );
となってしまった。size_tは、必ずunsignedであるとされる。
ならばこのプロトタイプ宣言は、伝統的なCと互換性がない事になる。
しかも、伝統的に int a = sizeof(buf); のように、sizeof() は符号付き int
を返す処理系が多かった。
一方、size_t は、sizeof()演算子の結果の符合なし整数とされる。
これもいろいろな意味で矛盾している。
C++11以降のC++はめちゃくちゃ。
int strlen( const char *str );
だったのが、なぜか、64BITにも対応した後は、
size_t strlen( const char *str );
となってしまった。size_tは、必ずunsignedであるとされる。
ならばこのプロトタイプ宣言は、伝統的なCと互換性がない事になる。
しかも、伝統的に int a = sizeof(buf); のように、sizeof() は符号付き int
を返す処理系が多かった。
一方、size_t は、sizeof()演算子の結果の符合なし整数とされる。
これもいろいろな意味で矛盾している。
C++11以降のC++はめちゃくちゃ。
352デフォルトの名無しさん
2021/04/22(木) 17:08:44.22ID:yNSfYish 何年前のものだか忘れてんじゃね?
まだ単一継承が宗教のような存在だった頃だぞ
これから新しく作るライブラリがああなってたらアホかとも思うが
当時そんな批評できてたやつを憶えているか?
まだ単一継承が宗教のような存在だった頃だぞ
これから新しく作るライブラリがああなってたらアホかとも思うが
当時そんな批評できてたやつを憶えているか?
353デフォルトの名無しさん
2021/04/22(木) 17:25:59.64ID:j9DIDz/e Cの教科書で、
int a;
a = strlen(ptr);
見たいなのはよく見た記憶が有るが、
size_t a;
a = strlen(ptr);
というのは記憶に無い。
昔はsize_tなんて型は本には書いてなかった。
ところがネットだととても昔からstrlen()の戻り値はsize_tであった
と言う事になってしまっていて、全世界的に事実を改竄している。
というか俺の記憶だけが世界の記憶と食い違ってる・・・。
int a;
a = strlen(ptr);
見たいなのはよく見た記憶が有るが、
size_t a;
a = strlen(ptr);
というのは記憶に無い。
昔はsize_tなんて型は本には書いてなかった。
ところがネットだととても昔からstrlen()の戻り値はsize_tであった
と言う事になってしまっていて、全世界的に事実を改竄している。
というか俺の記憶だけが世界の記憶と食い違ってる・・・。
354デフォルトの名無しさん
2021/04/22(木) 17:38:12.90ID:j9DIDz/e 「サイズは本質的に負になることは無いから、符号無しでよい」
なるほど、これには一理ある。しかし、ptr2 - ptr1 は、ptrdiff_t
で符号付きとされる。これは伝統的なCがそうであったから分かる。
しかし良く考えてみると、例えば32BITマシンで、2GBを越えるデータ
を扱う場合、確かにそのサイズは符合つきでは扱えないので符合なしで
良い。ところが、この場合、最後のバイトをptr2、最初のバイトをptr1
でアドレスしているとすれば、ptr2 - ptr1 は、2G を超えた値になる。
おー、となると、ptr2 - ptr1 を ptrdiff_t のような符号付きで解釈すると
負の数となる!!!
おう神よ!!
なるほど、これには一理ある。しかし、ptr2 - ptr1 は、ptrdiff_t
で符号付きとされる。これは伝統的なCがそうであったから分かる。
しかし良く考えてみると、例えば32BITマシンで、2GBを越えるデータ
を扱う場合、確かにそのサイズは符合つきでは扱えないので符合なしで
良い。ところが、この場合、最後のバイトをptr2、最初のバイトをptr1
でアドレスしているとすれば、ptr2 - ptr1 は、2G を超えた値になる。
おー、となると、ptr2 - ptr1 を ptrdiff_t のような符号付きで解釈すると
負の数となる!!!
おう神よ!!
355デフォルトの名無しさん
2021/04/22(木) 17:41:40.96ID:j9DIDz/e >>354
もう少し深く考えて見ると、ptr2 - ptr1 は、どちらが若いアドレスかが
わからない時でも結果を理解するためには、結果は符号付き整数である
ことには合理性がある。つまり、ptr2 < ptr1 なら、負、ptr2 > ptr1 なら
正と。
ところが、32BITマシンで、2GBを越えるデータを扱うと、この解釈では
問題が出る。
結論的には、sizeof()や ptr2 - ptr1 の結果の型に対してどんな場合にでも
上手く行く定義は存在しないようだ。
もう少し深く考えて見ると、ptr2 - ptr1 は、どちらが若いアドレスかが
わからない時でも結果を理解するためには、結果は符号付き整数である
ことには合理性がある。つまり、ptr2 < ptr1 なら、負、ptr2 > ptr1 なら
正と。
ところが、32BITマシンで、2GBを越えるデータを扱うと、この解釈では
問題が出る。
結論的には、sizeof()や ptr2 - ptr1 の結果の型に対してどんな場合にでも
上手く行く定義は存在しないようだ。
356デフォルトの名無しさん
2021/04/22(木) 17:41:51.85ID:yNSfYish K&R1にはsize_tなんか出てこない
strlenの戻り型はintとすら書いておらず
省略時の解釈で暗黙にintとなっている
strlenの戻り型はintとすら書いておらず
省略時の解釈で暗黙にintとなっている
357デフォルトの名無しさん
2021/04/22(木) 22:53:20.32ID:V05yroc1 std::string::size_typeは?
358はちみつ餃子 ◆8X2XSCHEME
2021/04/23(金) 02:30:22.88ID:4SxnyUW7 >>351
「伝統的」っていつの話だよ。
C89 が制定されて以降、 strlen の返却値や sizeof の評価結果の型は size_t だろ。
念のためにちょっと確認してみたら
Turbo C 1.0 なんて 1987 年の日付 (C89 制定前) だが strlen の返却値は size_t になってるぞ。
「伝統的」っていつの話だよ。
C89 が制定されて以降、 strlen の返却値や sizeof の評価結果の型は size_t だろ。
念のためにちょっと確認してみたら
Turbo C 1.0 なんて 1987 年の日付 (C89 制定前) だが strlen の返却値は size_t になってるぞ。
359デフォルトの名無しさん
2021/04/23(金) 02:54:05.85ID:ja7Blzf3 >>358
当時の本でも、
int a;
a = strlen(ptr);
と書いてあったと記憶してるので、指導的立場の人も含めてほとんどすべての人が
unsigned int の戻り値を int の変数に入れていたということだね。
当時の本でも、
int a;
a = strlen(ptr);
と書いてあったと記憶してるので、指導的立場の人も含めてほとんどすべての人が
unsigned int の戻り値を int の変数に入れていたということだね。
360デフォルトの名無しさん
2021/04/23(金) 03:11:41.40ID:ja7Blzf3 https://stackoverflow.com/questions/32985119/strlen-to-int-c-why-cant-i-do-this
↑こんなにC++に詳しそうな人達も、なぜか、符合無しの size_t を
intと比較している:
std::size_t length = s.size();
for (int i = 0; i < length; ++i)
どこかでC/C++の長さは、intであると刷り込まれているようだ。
しかし、35年以上前のTurbo C ですら、unsigned intであったのに。
↑こんなにC++に詳しそうな人達も、なぜか、符合無しの size_t を
intと比較している:
std::size_t length = s.size();
for (int i = 0; i < length; ++i)
どこかでC/C++の長さは、intであると刷り込まれているようだ。
しかし、35年以上前のTurbo C ですら、unsigned intであったのに。
361デフォルトの名無しさん
2021/04/23(金) 03:13:55.04ID:ja7Blzf3 質問者は、
for (int i = 0; int n = (int)strlen(s); i < n, i++)
がエラーになることの理由を聞いているようだが、これは単純に
for文の書き間違いで、少なくとも、
int i, n;
for (i = 0, n = (int)strlen(s); i < n, i++)
と書けばコンパイルは通るはずだ。
for (int i = 0; int n = (int)strlen(s); i < n, i++)
がエラーになることの理由を聞いているようだが、これは単純に
for文の書き間違いで、少なくとも、
int i, n;
for (i = 0, n = (int)strlen(s); i < n, i++)
と書けばコンパイルは通るはずだ。
362デフォルトの名無しさん
2021/04/23(金) 03:25:18.34ID:ja7Blzf3 スマン:
誤: for (i = 0, n = (int)strlen(s); i < n, i++)
正: for (i = 0, n = (int)strlen(s); i < n; i++)
誤: for (i = 0, n = (int)strlen(s); i < n, i++)
正: for (i = 0, n = (int)strlen(s); i < n; i++)
363デフォルトの名無しさん
2021/04/23(金) 05:23:38.34ID:wmFgppeg > どこかでC/C++の長さは、intであると刷り込まれているようだ。
これは違う
double a = 0;
と書いたからって0がdoubleと思っているのと違うようなものだ
これは違う
double a = 0;
と書いたからって0がdoubleと思っているのと違うようなものだ
364デフォルトの名無しさん
2021/04/23(金) 08:03:05.37ID:VR54cMAF365デフォルトの名無しさん
2021/04/23(金) 09:14:12.81ID:W3jbQ1id >>364
現代のガリレオかもしれない
現代のガリレオかもしれない
366デフォルトの名無しさん
2021/04/23(金) 14:58:50.01ID:Lj3XxxY0 >>365
ガリレオの時代にガリレオ以外に地動説を考えてた奴が他にいなかったと思い込む馬鹿。
ガリレオの時代にガリレオ以外に地動説を考えてた奴が他にいなかったと思い込む馬鹿。
367はちみつ餃子 ◆8X2XSCHEME
2021/04/23(金) 19:32:09.65ID:4SxnyUW7 >>360
その場合に int で表現可能な範囲内の値である限り暗黙の型変換で不整合は生じない。
strlen の返却値が size_t なのは、最大でそこまで対応可能ではあるが、
扱うデータの大きさが int の範囲内にあるという「想定」をしてもすぐさま誤りではないし、
int の範囲を超えるほど長大な文字列を想定しなきゃならない機会はそう多くもないだろ。
常識的な想定と言語仕様を混同するべきではない。
その場合に int で表現可能な範囲内の値である限り暗黙の型変換で不整合は生じない。
strlen の返却値が size_t なのは、最大でそこまで対応可能ではあるが、
扱うデータの大きさが int の範囲内にあるという「想定」をしてもすぐさま誤りではないし、
int の範囲を超えるほど長大な文字列を想定しなきゃならない機会はそう多くもないだろ。
常識的な想定と言語仕様を混同するべきではない。
>>365
私も、ある意見について「世界で自分だけ正しい、あとの70億人はすべて間違っている」という実感を持っています
問題はそれを世の中に知らしめす方法ですが、今の私はリアルで打撃につぐ打撃、その上におまけの打撃まで食らう状態で、いわば瀕死の状態‥‥
さてこんなボロボロな私はどうすればいいのでしょうか?
私も、ある意見について「世界で自分だけ正しい、あとの70億人はすべて間違っている」という実感を持っています
問題はそれを世の中に知らしめす方法ですが、今の私はリアルで打撃につぐ打撃、その上におまけの打撃まで食らう状態で、いわば瀕死の状態‥‥
さてこんなボロボロな私はどうすればいいのでしょうか?
369デフォルトの名無しさん
2021/04/23(金) 21:03:11.51ID:/ReE/HFJ その意見とは?
370デフォルトの名無しさん
2021/04/23(金) 22:13:51.83ID:P6csa9Qs >>368
氏ね
氏ね
371蟻人間 ◆T6xkBnTXz7B0
2021/04/23(金) 22:32:09.50ID:/PeODZRO >>368
短期目標と長期目標を立てて、目標に達成したら、自分を褒める。これを繰り返す。
短期目標と長期目標を立てて、目標に達成したら、自分を褒める。これを繰り返す。
372デフォルトの名無しさん
2021/04/23(金) 23:05:33.67ID:E6ocica9 >>368
ビッグバンからやり直せ
ビッグバンからやり直せ
373デフォルトの名無しさん
2021/04/23(金) 23:26:25.47ID:Q3jU6je8374デフォルトの名無しさん
2021/04/23(金) 23:40:13.99ID:dmQwGyWy375デフォルトの名無しさん
2021/04/24(土) 01:05:08.94ID:zTQKHVDv .hファイルと.hppファイルって何が違うんスかね
includeするならincludeしたがわの拡張子でコンパイル方法?が決まるわけで
ヘッダの拡張子の違いとは?
includeするならincludeしたがわの拡張子でコンパイル方法?が決まるわけで
ヘッダの拡張子の違いとは?
376デフォルトの名無しさん
2021/04/24(土) 01:15:37.87ID:h5KFlu4v .hには宣言だけ書いて.hppには実装を書くという使い分けをしている人が多い
宣言と実装を同時に行うときも .hpp
宣言と実装を同時に行うときも .hpp
377デフォルトの名無しさん
2021/04/24(土) 01:20:25.68ID:/oCjni0O STLコンテナに機能を追加したい (たとえば vector の要素の順番を自分のルールで並び替えるメンバ関数を追加したい) ときってどう書くのですか?
この場合はメンバ関数じゃなくてフリー関数として実装した方が良いとしても、メンバ関数を追加する方法を知りたいです
(それとも、STL コンテナの継承が忌避されるのと同じ理由で、こういうのはやらない方が良い話ですか?)
この場合はメンバ関数じゃなくてフリー関数として実装した方が良いとしても、メンバ関数を追加する方法を知りたいです
(それとも、STL コンテナの継承が忌避されるのと同じ理由で、こういうのはやらない方が良い話ですか?)
378デフォルトの名無しさん
2021/04/24(土) 01:32:10.18ID:UuNl8IKh >>377 継承すれば追加できるよ。
379はちみつ餃子 ◆8X2XSCHEME
2021/04/24(土) 01:45:45.85ID:ubeHrzBk380デフォルトの名無しさん
2021/04/24(土) 01:50:57.50ID:zTQKHVDv381デフォルトの名無しさん
2021/04/24(土) 02:37:44.86ID:/oCjni0O382デフォルトの名無しさん
2021/04/24(土) 03:09:41.49ID:CW6Yf84b >>381
STLはソース(ヘッダだけど)を見ると物凄く解読に時間が掛かる書き方になって
いて、正しく現状どうなって実装されているかを理解するのがとても難しいが、
継承するとなるとちゃんと理解出来てないと危険なので継承したがらない人が
多いのだと思う。
STLはソース(ヘッダだけど)を見ると物凄く解読に時間が掛かる書き方になって
いて、正しく現状どうなって実装されているかを理解するのがとても難しいが、
継承するとなるとちゃんと理解出来てないと危険なので継承したがらない人が
多いのだと思う。
383デフォルトの名無しさん
2021/04/24(土) 03:14:32.82ID:CW6Yf84b >>382
あと、テンプレートを普通のクラスの基本クラスにすることは容易だけど、
テンプレートを継承したテンプレートを作るのは、C++をかなり深く理解して無いと
色々と危険かも知れない。
また、ややこしくしてるのは、perfect forwarding や reference collapsing、
右辺値参照、moveセマンティクスが多用されていることに加えて、
余りドキュメント化されて無い解釈の難しい独自関数を使用して書かれている
ことが多いこと。
あと、テンプレートを普通のクラスの基本クラスにすることは容易だけど、
テンプレートを継承したテンプレートを作るのは、C++をかなり深く理解して無いと
色々と危険かも知れない。
また、ややこしくしてるのは、perfect forwarding や reference collapsing、
右辺値参照、moveセマンティクスが多用されていることに加えて、
余りドキュメント化されて無い解釈の難しい独自関数を使用して書かれている
ことが多いこと。
384デフォルトの名無しさん
2021/04/24(土) 03:21:35.70ID:CW6Yf84b >>383
それ以外にも、template引数に「...」があったり、それを使う場所でも「...」
があったりして、それぞれの意味や展開のされ方を正しく理解するのは難しい。
コンパイラがどういう解釈をするのか途方にくれることが有った。まるで
魔法のように見えることすら。結果的な意味は何とか分かっても、コンパイラが
どういう原理や順序で理解したりコンパイルしているのか深く理解できないこと
が多かった。
最新のSTLのソースをちゃんと理解できるまでC++を理解するのは、C++を
本格的に勉強する必要がある。
それ以外にも、template引数に「...」があったり、それを使う場所でも「...」
があったりして、それぞれの意味や展開のされ方を正しく理解するのは難しい。
コンパイラがどういう解釈をするのか途方にくれることが有った。まるで
魔法のように見えることすら。結果的な意味は何とか分かっても、コンパイラが
どういう原理や順序で理解したりコンパイルしているのか深く理解できないこと
が多かった。
最新のSTLのソースをちゃんと理解できるまでC++を理解するのは、C++を
本格的に勉強する必要がある。
385デフォルトの名無しさん
2021/04/24(土) 03:41:23.64ID:CW6Yf84b >>384
古いC++にも「initializer list」という言葉はあったが、C++11以降は
独特の概念が追加され、それに関連したオブジェクトを関数の引数にとったり
できるようになったりして、それの働きを深く理解するのがまた難しい。
また、全体的に lvalue, rvalue に加えて、xvalue, prvalue, glvalueを正確に
理解し、何がどれに属するかを徹底的に理解してなければ、STLのソースコードを
正確に理解することはままなら無い。
僅かでも理解してないことがある状態でSTLのコンテナを独自に継承した
テンプレートを作った場合、思わぬ不具合やメモリー関連の原因が特定しにくい
バグをアプリ開発で忙しい時に遭遇してしまうかも知れない。
古いC++にも「initializer list」という言葉はあったが、C++11以降は
独特の概念が追加され、それに関連したオブジェクトを関数の引数にとったり
できるようになったりして、それの働きを深く理解するのがまた難しい。
また、全体的に lvalue, rvalue に加えて、xvalue, prvalue, glvalueを正確に
理解し、何がどれに属するかを徹底的に理解してなければ、STLのソースコードを
正確に理解することはままなら無い。
僅かでも理解してないことがある状態でSTLのコンテナを独自に継承した
テンプレートを作った場合、思わぬ不具合やメモリー関連の原因が特定しにくい
バグをアプリ開発で忙しい時に遭遇してしまうかも知れない。
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- バリ島で男子生徒ら集団万引きか、防犯カメラ映像が拡散 京都の大谷中学・高校が「窃盗行為」謝罪★4 [七波羅探題★]
- 【地震速報】青森県で震度6強 沿岸部に津波警報 ★6 [ぐれ★]
- 中国軍機レーダー照射、トランプ氏沈黙突く 試される日本外交 [蚤の市★]
- 【速報】気象庁は津波注意報すべて解除 [蚤の市★]
- 【サッカー】58歳カズ「オファーが来ている」 J3福島と近日中にも交渉 早ければ年内にも決断 [征夷大将軍★]
- 「日の丸にバツ印」掲げた大学生 あいまいな国旗損壊罪に「怖い」 The Mainichi [少考さん★]
- 働いて参ります
- ( ・᷄ὢ・᷅ )あ?
- 地震
- こんぺこ!こんぺこ!こんぺこ!🐰🏡
- 早大名誉教授「高市内閣の高支持率はデータ操作か、支持している日本人がアホなのか」👈核心を突いてしまう [868050967]
- ブタをぶったたく
