C++相談室 part152

■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
垢版 |
2020/07/12(日) 13:42:20.13ID:TX1mpKr6
https://mevius.5ch.net/test/read.cgi/tech/1589424805/
2020/09/23(水) 01:33:58.69ID:JzGrrpxj
sprintf_s()と_countof()をセットで標準にしてホスイ
2020/09/23(水) 01:40:34.94ID:2N0Iktsg
>>497
C だと _countof に相当するものは欲しいなと思うが、
C++ 的には std::size か std::extent を使いたまえ。
2020/09/23(水) 01:44:08.47ID:wtMA3RXJ
>>493
>元からイケてない変数宣言の文法を部分的にどうにかすっきり見せる
一般的なポインタを表現するためには、どうしても、宣言子の中にも型の一部を
書くべきだったので、文法がそのように選択され、
int* a;
ではなく、
int *a;
と書く方がその記法と統一感がある。
数学者や物理学者は一般性や統一性がある方が美しいと感じる人が多いと
言われており、通常、数物の世界で「美しい」というのは、統一性のある
書き方。
なので、C/C++の型でも、後者の方が美しく感じるのが数物系の才能がある
人の感覚。
2020/09/23(水) 01:47:03.11ID:SSau2msF
>>496
どんな判断だよ
libfmt使えばいいじゃん
501デフォルトの名無しさん
垢版 |
2020/09/23(水) 01:50:27.78ID:wtMA3RXJ
>>499
ポインタだけでなく、配列も、
int a[3];
の様に書く。これも、人気言語であったBASIC言語の
DIM a(3)
と似た感覚となっている。
配列はもちろん型の一部ではあるが、これを
int[3] a;
と書いて分かり易いとは限らない。というのは、
配列を使う場合には、BASICの場合ではa(i)、Cの場合では、a[i]のように書くので、
これも、宣言に置いても、BASICやCの書き方の方が分かり易いと思うのも自然。
それに
int *ptr_s[3];  // (100)
のような場合に、分かり易く型を全て左に書くのは難しい。
書くとすれば、
int*[3] ptr_s;
となるが、これが果たして分かり易いかと言えばNoだろう。
使う場合には、ptr_s[i] が int へのポインタになるのだから、
(100)の記法は至って分かり易い。
2020/09/23(水) 01:55:10.68ID:2N0Iktsg
>>499
> どうしても、宣言子の中にも型の一部を書くべき

それを前提とするならそれと一貫させることを俺は否定してない。
でも前提とできないよねという話をしてるんだから
なんで「べき」なのかを説明しないとなんの主張にもなってないよ。
2020/09/23(水) 01:55:45.37ID:wtMA3RXJ
>>501
さらにいえば二次元配列の場合、宣言は、
int a[3][2]; //C。使う場合は a[i][j]
DIM a(3,2); //BASIC。使う場合は、a(i,j)
となるが、もしCで型を全て左に書くとすれば、
int[3][2] a;
となると思うかもしれないが、これは、数学的な統一性からすれば
間違いで、正しくは、
int[2][3] a;
となり、前後を逆に書くのが「正しい」。
これが即座に理解できる人が数学的才能が有る人で、
教えてもらわないと分からない人才能が無い。
2020/09/23(水) 02:05:33.12ID:wtMA3RXJ
>>502
Cの記法は、物理学で言うところの「組立単位」に相当する「組み立て型」を
一般的に表現するためには、かなり美しく正しい選択をしている。
int *a[10]; // (1)
int (*a)[10]; // (2)

は、物理学のように言えば、int-ptr-array-aとint-array-ptr-aの違いを
表しているが、Cの表現はとても理にかなっており非常に分かり易い。
これらの型を全てまとめて左に書こうとすれば、書くことは出来て、
int*[10] a; // int-ptr-array-a, (10)
int[10]* a; // int-array-ptr-a, (11)
となるが、果たしてこれが分かり易いかどうかと言う問題となる。
それぞれを使う際の a[i] や、*a の表記と(1), (2)に上手く対応しているので、
(10),(11)よりも統一が取れており、数学的には「美しい」状態となっている。
2020/09/23(水) 02:18:13.45ID:wtMA3RXJ
>>502
それは、>>503>>504 のようなことがあるから。
2020/09/23(水) 02:24:26.38ID:wtMA3RXJ
>>502
C言語のように「書くべき」ことが分かる一番分かり易い例は、Cで
int a[1][2][3][4];
と書くものが、全部左に型を書く記法だと
int[4][3][2][1] a;
と書かないと、組み立て型(物理学における「組立単位」に相当)における
一般性を失うが、それだと、使う際の a[i1][i2][i3][i4]と要素数の指定とが
直感的に逆さまになってしまう問題が起きる。

もし、
int[1][2][3][4] a;
のように書くと、一般性を失い、組み立て型としては破綻しまい、その場しのぎの
記法となってしまう。
もしこれが理解できないのなら、悪いけど、数学的才能や、コンパイラを設計する才能が無い。
507デフォルトの名無しさん
垢版 |
2020/09/23(水) 02:24:53.28ID:VKAwJeUe
どうでもよい
2020/09/23(水) 02:27:39.29ID:SSau2msF
じじいはこういう語りつくされた古い話題しか話せないからな
509デフォルトの名無しさん
垢版 |
2020/09/23(水) 02:55:43.29ID:VKAwJeUe
大工が金槌はこうでなくてはならない(家を作ったことない)
510デフォルトの名無しさん
垢版 |
2020/09/23(水) 02:56:47.86ID:VKAwJeUe
この手の輩はいないほうがいい
邪魔
511デフォルトの名無しさん
垢版 |
2020/09/23(水) 02:58:20.51ID:VKAwJeUe
クソみたいなマウント合戦を繰り広げる老害であることを自覚しろ
2020/09/23(水) 02:59:44.49ID:2N0Iktsg
>>504
数学的・物理的な美しさを (仮に (あくまでも仮に) その主張が妥当だとしても) C++ スレで根拠にするのが不思議。
そんな美しさなんてどうでもいいもの。

こちらの主張は

宣言の文法が型名とは別にある
→ その時点で一貫性なんてないよ
→ どちらを軸にすることもありうる
→ でもまあ C++ の発展の様子からすると型名を軸にしたさが見えるね

って話で、現時点で無い文法を導入したいとか思っているわけでもないし、
存在する文法を絶対に駄目だというわけでもない。

とはいえ (話の大元に戻るが) 現在の C++ が typedef を冷遇しているので、
なるべく using を使ったほうがいいよねってだけ。
513デフォルトの名無しさん
垢版 |
2020/09/23(水) 04:12:53.08ID:VKAwJeUe
わしのFormatterは
int* a;
int *a, *b, c;
のように整形しよる。これが落とし所として妥当であろう
2020/09/23(水) 05:07:59.09ID:J9lXF67O
>>500
https://github.com/fmtlib/fmt
でしょうか?github になれてなくて、これを使う方法もよくわからないし…
20年使っている sprintf() でもういいや…って妥協してしまいました
手元のコンパイラは g++17, 職場のは g++11 だけれども、セキュリティが堅くて「無断で」cygwin をアップデートさせてもらえない…
必要に迫られて徹夜して間に合わせたけれども、プログラミングへの集中力はずいぶんと落ちてしまいました…

コメントありがとうございました
2020/09/23(水) 07:58:28.38ID:fDvsnE+M
>>506
auto signal(int, void(*fp)(int)) -> decltype(fp); //こう書かれたら「破綻」で読めなくなるのか? おまえさんは
それこそC++11のグラマーが読めない、つまり数学的才能に乏しいことになるぞ
2020/09/23(水) 08:04:19.35ID:fDvsnE+M
>>512
あいつ結局Cの文法と設計思想を説明してるだけだよな
それをC++11の文法と設計思想を否定する根拠にしようとしているようだが
筋違いというか脈絡がない

ぼくはusing使いたくないんだーtypedef使うのを邪魔すんなー
僕はものすごく数学と物理に詳しいんだーセンスないやつうるせー
2020/09/23(水) 09:08:00.93ID:wtMA3RXJ
数学や物理学は、2000年以上も続く巨大なエコシステムを持っており、
それ以上簡潔にならないくらいな表現方法を発明済み。
それとは別の表現をしてもそれらを超えることはまず不可能で、文系の人達の
自己満足に過ぎない。
2020/09/23(水) 09:23:45.36ID:fDvsnE+M
思っクソ関係ない
話せば面白そうな気がしたがそっちへ行くのね
あーあ残念
2020/09/23(水) 09:33:29.79ID:wtMA3RXJ
最近の「モダン」言語は、既存のものを知らずに新しいものを作ろうとする傾向が目立つ。
彼らは、今までの理論などそのメリットが理解出来ておらず、効率の悪い、
分かりにくい、整合性の無い、その場しのぎで、一般性が無い記法を導入する。
2020/09/23(水) 09:58:47.10ID:fDvsnE+M
つまんね
521デフォルトの名無しさん
垢版 |
2020/09/23(水) 10:19:32.59ID:hJkRvCZv
>>503
えっ?
そもそも
int a[2][3]; //C。使う場合は a[j][i]
DIM a(3,2); //BASIC。使う場合は、a(i,j)
じゃないのかな

>>499 は支持する
522デフォルトの名無しさん
垢版 |
2020/09/23(水) 10:22:59.31ID:hJkRvCZv
>>506
ここもおかしい

元々
int a[4][3][2][1];
と書くべき
2020/09/23(水) 11:04:51.52ID:tBUnvPYy
分かりにくい文法で自爆ってダサすぎるなw
そもそもC++なのに素の多重配列使うって
センスなさすぎだし
2020/09/23(水) 12:28:26.75ID:OXXcv7E7
>俺は数学が好きで、学生時代、ほぼ満点だった。

数物系が得意な人が、こんな馬鹿っぽくて曖昧な書き方するのかね?
この情報でどうやってお前の能力を推し量れと
525デフォルトの名無しさん
垢版 |
2020/09/23(水) 12:31:30.53ID:YfY3TQQ4
正直マジレスするアホが居るとは思いもよらなんだ
2020/09/23(水) 14:09:17.34ID:Ywvud/Qy
>>493
なんでもテンプレートに書き直せばいいってもんでもない
2020/09/23(水) 17:58:15.39ID:fDvsnE+M
CでもそうだけどC++を使うからにはC++らしく使いたいね
C訛りのたどたどしいC++からは早く脱したい
2020/09/23(水) 17:59:58.72ID:fDvsnE+M
Cで憶えたことがとりあえず使えるのがC++に用意された入りやすい門ではあるけどね
そこは振り出しでしかないんだよ
2020/09/23(水) 19:14:29.97ID:qJkmihKT
>>493みたいなのをC++らしい、と思ってるならだいぶアレだけどな
2020/09/23(水) 19:48:39.67ID:S15h3SjP
仕事で使うならBetter Cで留めるのが正しいC++の使い方。
531484
垢版 |
2020/09/23(水) 20:09:34.36ID:7wSVczyT
>>493
> std::add_pointer_t<int()> f;
> std::decay_t<int()> f;

(´・∀・`)ヘー
そんなんあるんですね
勉強になりました

>>529
凄くC++らしいと思うけどw
意地でもテンプレートで何とかしようというのは
2020/09/23(水) 20:16:22.00ID:J9lXF67O
>>524
確かに、数物系に「特異」な人のコメントにしては貧弱だなあと、私も思いました
たとえばガロア理論、とか、相対性理論、超弦理論、とか、を熱っぽく語って欲しいです

個人的にはエルゴート理論について薀蓄を知りたいですね
2020/09/23(水) 20:16:56.39ID:J9lXF67O
>>527
でも iostream は失敗作という気がふつふつと…(略)
2020/09/23(水) 20:38:06.09ID:wsuhqGJa
c++らしいって言っても時代によってかなり変わるし無意味な言い回しだわ。
2020/09/23(水) 21:11:40.16ID:7wSVczyT
時代によってかなり変わるの?
C++98以降しか知らないけど
C++らしさ=テンプレート
と断言していいほどの一点張りだと思うけど(個人の感想です)
2020/09/23(水) 21:58:09.41ID:wsuhqGJa
もうどこから突っ込んでいいかわからんくらい馬鹿
2020/09/23(水) 23:12:26.96ID:fzdYgRfo
ここまで喧喧諤諤の多くの意見が飛びかっておるが
iostream は要らん子、というのは一致しておるな
とくに operator << >> 系のやつ
2020/09/23(水) 23:42:00.61ID:0XTX+Fu9
coutで出力するよりstd::stringに一旦文字列化してからprintf()で出した方が速いという時点で以下略
2020/09/23(水) 23:55:04.80ID:2N0Iktsg
個人的には iostream をそこそこ好きなんだが、
今だったらこんな設計はしないだろうなというのはとてもよくわかる。
2020/09/24(木) 00:04:29.70ID:f1TxZ5Sj
>>535
互換性を捨てられない以上は汚い部分も捨てられないんだよね。
だからどうやって抽象化層をかぶせるか、もっと直接に言えば
汚い部分をどう隠すかというのが C++ らしさじゃないかな。

そして型 (または型の表記) に関して汚い部分を隠す道具としては
テンプレートは特に有用なもののひとつだとは思う。

ただ、一点張りは言い過ぎで、取れる手段、手数の多さも C++ らしさだというのが私の感想。
組み合わせよう。
2020/09/24(木) 03:03:21.13ID:yc5bnmE2
printfで%dとか%zとか指定するのめんどいやん
542デフォルトの名無しさん
垢版 |
2020/09/24(木) 03:09:46.41ID:sKL6gd3p
printfはバッファオーバーフローの脆弱性を産みやすい
543デフォルトの名無しさん
垢版 |
2020/09/24(木) 03:10:26.11ID:sKL6gd3p
早いとか以前の問題
2020/09/24(木) 05:20:27.18ID:bfjF2pM4
>>531
>意地でもテンプレートで何とかしよう
"自分でテンプレート書いて"色々どうにかしてる人が言うならまだ説得力もあるけどね
add_pointer_tとかdecayは基本的に標準ライブラリの実装(のためのメタプログラミング)の上での副産物だろ
テンプレートの文脈(=受け取った型に、場合により変換を施す必要がある)でもないとこでそんなん使って
「C++らしい」とか、だいぶ痛々しい

まぁ別に使用を禁止されてるわけでもないから使いたきゃ好きにすればいいけどね・・・
545デフォルトの名無しさん
垢版 |
2020/09/24(木) 06:18:07.32ID:sKL6gd3p
>>544
同意
2020/09/24(木) 06:37:36.81ID:n05mXSO9
>>533
まあね、俺も禿1からの付き合いだけど
未だによくわからんところはある

iostreamに限ったことじゃなく古株のクラスライブラリって
だいたい今作るならこうはしないってところが何かあるね
大きな実害なければ我慢するし
困る場合はそれこそ腕が鳴るチャンス
2020/09/24(木) 06:40:25.74ID:n05mXSO9
>>535
たとえばだけど、二次元配列がいるならクラス化するとかね
人によるだろうけどvector<vector<int>>は俺あんまりやりたくない
2020/09/24(木) 06:48:44.27ID:n05mXSO9
用意されているものを使っただけだろ
意地でもとかバイアスが入るのはコンプレックスの顕れだからこそ
ギャンギャン強弁してくるわけだ
2020/09/24(木) 07:02:36.59ID:4EukrBNz
>>542
printfでバッファオーバーフロー?
お前器用なやつだな
2020/09/24(木) 07:04:12.32ID:bfjF2pM4
decayに_t付けるの忘れてた
>>548
それ誰に向けて言ってるの?
2020/09/24(木) 07:09:28.96ID:n05mXSO9
返事をするのは心当たりがあるという自己申告かな?
2020/09/24(木) 07:14:45.36ID:bfjF2pM4
なんか口調でわかるわ、いつものアホか・・・
「>」これが付いてるのは引用箇所だからな、覚えとくといいよw
2020/09/24(木) 07:33:47.41ID:n05mXSO9
俺はまだ誰にとも言ってないんだがw
2020/09/24(木) 07:40:21.81ID:bfjF2pM4
はいはいわろすわろす
2020/09/24(木) 08:57:55.68ID:55R+R5Lh
printf, scanf系はtypedef型の正体を知っておかねばならないとかクラス型を基本型と同等に扱えないとかモロモロあるのに
いつまでもマンセーしててもしゃーないで
556デフォルトの名無しさん
垢版 |
2020/09/24(木) 09:00:20.65ID:sKL6gd3p
>>549
いや普通にありえるからググってわかる程度のこと聞くなよ
2020/09/24(木) 09:01:54.41ID:n05mXSO9
>>555
typedefの正体を意識してprintf/scanfを使うのは
privateでデータメンバを隠す話と真っ向逆だね
2020/09/24(木) 09:12:36.08ID:afeC5pu7
最終出力がわかりにくいとかロケール対応しにくいとかあるわけだけど
引数順にしか出力できない時点でprintfもロケール対応のやりにくさは変わらん
2020/09/24(木) 09:31:03.57ID:+pWNIbO4
>>556
ググっても出てこないぞ
560デフォルトの名無しさん
垢版 |
2020/09/24(木) 09:40:43.54ID:sKL6gd3p
ググりかたから教えなきゃならんの?
相手にしてられんわ
2020/09/24(木) 09:44:41.22ID:n05mXSO9
>>558
そんなあなたにput_money, put_time
2020/09/24(木) 10:57:49.94ID:afeC5pu7
>>561
ロケールと書いたのが悪かったな
多言語化だな
語順を変えるとかやりにくい
Pythonのようにフォーマット文に引数の順番をかければ
言語による語順の違いもフォーマット文の差し替えだけで済む
2020/09/24(木) 11:05:22.76ID:7yQWIIk2
>>562
安易に考えすぎ
実際にやってから言え
2020/09/24(木) 12:32:18.71ID:QU112yU2
>>556
ググれー
で逃げる気マンマンでワロタ
おとなしくsprintfでした、ごめんなさい
って言ってりゃいいのにw
2020/09/24(木) 12:43:09.70ID:G65zjecI
>>547
boost::numeric::ublasとか使えばいい。
2020/09/24(木) 12:47:12.82ID:n05mXSO9
>>562
ああ確かに語順の変え方はprintfと変わらんな
auto time_v = time(nullptr);
cout << put_time(localtime(&time_v), "%m/%d/%y %H.%M'%S");
567デフォルトの名無しさん
垢版 |
2020/09/24(木) 13:45:56.89ID:sKL6gd3p
>>564
お前も本当にゴミだな
wikipediaのリンク貼っといてやるよ
ほら
https://ja.wikipedia.org/wiki/%E6%9B%B8%E5%BC%8F%E6%96%87%E5%AD%97%E5%88%97%E6%94%BB%E6%92%83
568デフォルトの名無しさん
垢版 |
2020/09/24(木) 13:47:01.22ID:sKL6gd3p
まじでバカはしね
2020/09/24(木) 14:13:22.68ID:n05mXSO9
その話のどこがバッファオーバーフローなんだ?
570デフォルトの名無しさん
垢版 |
2020/09/24(木) 14:23:05.33ID:sKL6gd3p
>コールスタック上のリターンアドレスを書き換えて不正なコードを実行させる
571デフォルトの名無しさん
垢版 |
2020/09/24(木) 14:24:13.29ID:sKL6gd3p
自分の過ちを認めろと言う割に自分は謝らず図々しく更に無駄な質問を重ねるとは
2020/09/24(木) 14:30:21.28ID:EUYXPM4X
>>565
boostは標準規格外なので却下
2020/09/24(木) 14:38:20.48ID:n05mXSO9
>>570
バッファオーバーフローさせるだけではコールスタック上のリターンアドレスは狙えないぜ
同じ記憶域期間を持つ他のオブジェクトを破壊する可能性があるというだけだ
コールスタック上のリターンアドレスを狙うなら配列でないオブジェクトのアドレスにオフセットかけるだけでもできるしな
逆に自動変数のアドレスを確実に得る技術が必要になる

printf/scanfといえばバッファオーバーフローという固定観念に囚われているから
そういう読みになっちまうんだよ
574デフォルトの名無しさん
垢版 |
2020/09/24(木) 14:46:00.53ID:sKL6gd3p
まともに日本語の文章も読めないようじゃプログラムは君には難しいよ
575デフォルトの名無しさん
垢版 |
2020/09/24(木) 14:49:15.10ID:sKL6gd3p
メモリ位置にあるデータを確認できると書いてあることすら読めてない
576デフォルトの名無しさん
垢版 |
2020/09/24(木) 14:54:12.15ID:0BhvwOmc
おまわりさんこのひとです
577デフォルトの名無しさん
垢版 |
2020/09/24(木) 14:55:32.81ID:sKL6gd3p
おとなしく、日本語もググるのも難しくてひとつずつ教えてもらわなきゃできません
ごめんなさいって言ってりゃいいのにw
2020/09/24(木) 14:59:43.90ID:n05mXSO9
>>575
俺、自動変数のアドレスを確実に得る技術って言ったけど
おまえさんは、これが何のことかわかってる?

printf/scanf関係ないんだがw
579デフォルトの名無しさん
垢版 |
2020/09/24(木) 15:11:43.38ID:sKL6gd3p
Wikipediaまで引用してあげたのにまだごねるのか
本当にわがままだな
580デフォルトの名無しさん
垢版 |
2020/09/24(木) 15:12:12.34ID:sKL6gd3p
ばかはしね
2020/09/24(木) 15:48:16.32ID:n05mXSO9
> printfはバッファオーバーフローの脆弱性を産みやすい

重箱の隅な記事では、最後の「やすい」という主張の裏付けにはならないってことだ
粗暴な罵倒語も裏付けになるわけがないな
582デフォルトの名無しさん
垢版 |
2020/09/24(木) 15:53:47.24ID:sKL6gd3p
そんなにprintf好きなら勝手に使えばいいんじゃない?
583デフォルトの名無しさん
垢版 |
2020/09/24(木) 16:06:33.08ID:0BhvwOmc
おまいら printf の戻り値は毎回チェックしろよ
2020/09/24(木) 16:26:18.33ID:VqYlbH9U
printfの書式にユーザ入力を使うことなんてあるか?
SQLインジェクションとはワケが違うぞ
2020/09/24(木) 17:02:36.61ID:EUYXPM4X
バッファ使ってるsprintfと
バッファ使ってないprintfの
違いもわからんのか
2020/09/24(木) 17:26:51.00ID:5Fx1JvjP
確かにprintfの書式文字列に関するメモリ破壊の脆弱性が示されてるが、これを「バッファオーバーフロー」と呼ぶのは違和感があるな
587デフォルトの名無しさん
垢版 |
2020/09/24(木) 17:33:32.86ID:sKL6gd3p
わかってないくせに危険な関数使うなよ
588デフォルトの名無しさん
垢版 |
2020/09/24(木) 17:34:56.21ID:sKL6gd3p
パフォーマンスとか以前の問題だろうが
589デフォルトの名無しさん
垢版 |
2020/09/24(木) 17:36:15.17ID:sKL6gd3p
>バッファ使ってるsprintfと
それ勝手に持ち出したのお前だからなw
2020/09/24(木) 18:19:48.23ID:7yQWIIk2
こっからどう乗り切る気?
2020/09/24(木) 18:21:49.52ID:9cj79wpF
結局のところ、>>542が恥ずかしい奴だったという結論でok?
592デフォルトの名無しさん
垢版 |
2020/09/24(木) 18:26:33.04ID:sKL6gd3p
>>591
お前みたいな頭悪いやつが多くて
何も有益な話にならないから解散
という結論
593デフォルトの名無しさん
垢版 |
2020/09/24(木) 18:37:51.09ID:sKL6gd3p
cout << ...
がダサいだのprintfが早いだの
程度が低いんだよ
2020/09/24(木) 18:48:48.99ID:TdIgAD6o
>>592
ん?
バッファーオーバーフローとメモリー破壊の区別もつかないアホがドヤって撃沈だろ?
ダサすぎるw
595デフォルトの名無しさん
垢版 |
2020/09/24(木) 18:53:55.27ID:sKL6gd3p
適当に脳内で読み替えとけや無能
こっちはprintfなんてそもそも使わんから詳しいことに興味はない
だからググれって最初に伝えたんだわ
596デフォルトの名無しさん
垢版 |
2020/09/24(木) 19:02:40.95ID:sKL6gd3p
>>594
じゃあメモリ破壊とバッファオーバーフロー
でリターンアドレスの書き換え方が
どう違うのか説明してみ
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。