X



C++相談室 part134
■ このスレッドは過去ログ倉庫に格納されています
0001デフォルトの名無しさん (ワッチョイ 5fcb-Q2eK)
垢版 |
2018/01/20(土) 09:05:42.21ID:mJKRg6iz0
次スレを立てる時は本文の1行目に以下を追加して下さい。
!extend:on:vvvvv:1000:512

C++に関する質問やら話題やらはこちらへどうぞ。
ただし質問の前にはFAQに一通り目を通してください。
IDE (VC++など)などの使い方の質問はその開発環境のスレにお願いします。

前スレ
C++相談室 part133
http://mevius.5ch.net/test/read.cgi/tech/1511509970/

このスレもよろしくね。
【初心者歓迎】C/C++室 Ver.102【環境依存OK】
http://mevius.5ch.net/test/read.cgi/tech/1509780815/

■長いソースを貼るときはここへ。■
 http://codepad.org/
 https://ideone.com/

[C++ FAQ]
https://isocpp.org/wiki/faq/
http://www.bohyoh.com/CandCPP/FAQ/ (日本語)
VIPQ2_EXTDAT: default:vvvvv:1000:512:----: EXT was configured
0229デフォルトの名無しさん (ワッチョイ 1f7e-T3WU)
垢版 |
2018/02/18(日) 15:46:49.02ID:Tc3/Tap60
入れる変数の型と引数の型を確認しない奴とかいるのか
暗黙の型変換は警告を出せばいいし
どうしても見落とすのならコンパイルエラーにしてしまえばいい
あとメンバ変数もテキストの色を変えればいいからm_もいらない
0233デフォルトの名無しさん (ワッチョイ 9f12-pjg9)
垢版 |
2018/02/18(日) 21:14:42.68ID:SQcbDAgv0
ちげえんだよなぁ
thisというキーワードが存在してるから、その存在そのものが、それを書かねばならないような強制力を産み出してる
「存在するが、書かなくてもいい」っていうどっちつかずが、一番論争になる

その反対が「存在しないから書けない」だ
これだと単純明快だ
なんせ、書けない

「書くべきか書かざるべきか」のどーーーでもいい二択に迫られると、とたんに宗教になる
0239デフォルトの名無しさん (ワッチョイ d77f-T3WU)
垢版 |
2018/02/18(日) 22:00:36.01ID:tWqaO5mz0
m_xxx も xxx_ もなんの保証にもならんからな
this->は必ずメンバになるけど
0242デフォルトの名無しさん (ワッチョイ bf0e-qi38)
垢版 |
2018/02/18(日) 23:21:23.43ID:AjuHfv4B0
thisで明示した方が所在がハッキリして良いナリ
当職は名前空間もusingせずに明示しろ派ナリ
安易な省略はタイプ数を減らすという軽微なメリットと引き換えに可読性を落としケアレスミスを誘発するという恐ろしいデメリットを孕むナリ
0245デフォルトの名無しさん
垢版 |
2018/02/19(月) 00:18:14.94
C/C++なら必然的に末尾に付けるしかない
先頭に_付けるような情弱は死ねばいい
Perl/Pythonだと先頭に付けるけどな
0247デフォルトの名無しさん (ワッチョイ 1f7e-T3WU)
垢版 |
2018/02/19(月) 00:57:15.60ID:hDVR9PRD0
未定義なのは
_始まりでグローバルスコープにあるもの
_始まりでアルファベットの大文字が続くもの全て
__で始まるもの全て

1番目の_始まりなだけならローカル変数、引数、メンバでは予約されていないので使ってもよい
0250デフォルトの名無しさん (ワッチョイ 1f7e-T3WU)
垢版 |
2018/02/19(月) 02:05:55.66ID:hDVR9PRD0
コーディング規約はうろ覚えだけど自由度の高いBoostスタイルを薦める

publicな識別子はstdに合わせて小文字スネークケース
マクロはBOOST_から始める
インデントはスペース、一行の文字数は80文字を推奨
意味のある名前を付けることを推奨
ファイル構成に関するもの
その他細々としたもの
ライブラリごとのローカルルールがある場合もある

あとは自由
thisを付けろだとか改行の仕方だとかは一切書かれてない
0251デフォルトの名無しさん (ワッチョイ bf0e-qi38)
垢版 |
2018/02/19(月) 02:37:36.58ID:SEa8F8NC0
>>248-249
お互いにマナーを守る世界は過ごしやすいがマナーの厳守を要求し出すと途端に息苦しくなるナリ
自分にも他人にも読み易いコードを書こうという気遣いが見て取れるなら細かく突っ込んだりはしないナリ
0253デフォルトの名無しさん (アウアウアー Sa4f-rtnb)
垢版 |
2018/02/19(月) 12:45:29.69ID:yTAVcy/Ya
使うライブラリや開発環境の内部のスタイルに合わせるけどな。
派生クラスとかAPIのラッパークラスとか作り始めると、
どうしても内部の書き方に合わせておいた方が読みやすいし。

今でもWin32とかMFCでやることもあるけど、
そのときはm_とかpとかhとかdwとかバンバンつける。
0254はちみつ餃子 ◆8X2XSCHEME (ワッチョイ bf6f-T3WU)
垢版 |
2018/02/19(月) 13:19:17.15ID:gMMBYzvP0
使う側の都合に合わせろよ。 ラップしてるのに中身のスタイルが漏れてるんじゃラップの甲斐がなくね?
中身を知ってる人がちょっとした便利のためだけに薄いラッパを作る場合ならそういう選択もあるだろうけど。
0255デフォルトの名無しさん (ワッチョイ 9f9d-MriG)
垢版 |
2018/02/19(月) 14:36:30.11ID:00nJVfHA0
コンバータにあわせろよ。C#で作ってコンバータかけた方が綺麗スッキリするんだから。
0258 ◆QZaw55cn4c (ワッチョイ 9f60-qi38)
垢版 |
2018/02/21(水) 00:43:21.00ID:jU0tYaxw0
Windows メインで作業されている方で、
valgrind を併用している方はおられませんか?
もしよろしければ使用感をお聞かせいただけませんか

operator new()/operator delete() 乗っ取りデバッグに限界を感じてしまっている状況です
(cl や bcc32/bcc32c/bcc64 では new/delete 乗っ取りができません)
いや、さっさと入れればいいのですが、仮想環境とかよくわからないし…Vine Linux 以来触ってないし…
0263260 (マクド FF6b-xgEu)
垢版 |
2018/02/21(水) 19:34:37.06ID:EmINyJBAF
すみません、BOOST_TTI_HAS_MEMBER_FUNCTIONを使って短くする以前に元々が間違っていました。
以下の3つでオーバーロードしたかったのでした。
・funcというメンバ関数を持つダブルポインタ
・funcというメンバ関数を持たないダブルポインタ
・それ以外

それで思ったのですが多分、Boost.TTIライブラリで
〇〇というメンバ関数を持つクラス、を識別するメタ関数は作れても
〇〇というメンバ関数を持つクラスのダブルポインタ、は無理な気がしてきました。
一旦諦めようと思います。
0267デフォルトの名無しさん (ワッチョイ c667-x4Or)
垢版 |
2018/02/22(木) 21:55:24.65ID:qwLRFwLN0
システムハンガリアン発祥の会社が何か作ったら否定論者がぎゃふんと言うのか?
おまえの頭の中は論点先取だか循環論法だかがグルグル回っているようだな
0271デフォルトの名無しさん (ワッチョイ ba12-SJjx)
垢版 |
2018/02/24(土) 10:44:07.22ID:mn7A8TMg0
一分間で間違いに気づいてはいるものの
そもそもの書く瞬間にはどうやら人智を用いても気付けないらしいから
IDEにエラー出してもらった方が早いんじゃあねえの

実は人間の集中力を超えたところにある方法論で、実践するとストレスが溜まるっぽいから、機械任せにした方がいい
それに、書いてる最中は変数の型まで考えたくない

見て分かることは、機械任せにすれば見なくても分かるから、
今のご時世、人間の有限の集中力を目視チェックなんかに使いたくない
脳みそのリソースはもっと別のところに使うべきだ

つまりは、書いてる最中は脳みそが「それが正しい」と思い込んでるから、
間違いは自分自身では絶対に分からない
これがバグを作り込む
hだったかdwだったかを脳が自動的に混同してるから、その分だけ余計に脳のリソースを使っている

「なんで書いている最中に自分自身で気付かないのか」、これ、とても重要だよ
0272デフォルトの名無しさん (スップ Sd02-2/+O)
垢版 |
2018/02/24(土) 11:11:20.01ID:51zBno3Kd
変数名と型が一致してるという保証がゼロだからシステムハンガリアンなんて無駄以外の何物でもない
無駄というか悪
0277デフォルトの名無しさん (ワッチョイ 520e-MTlB)
垢版 |
2018/02/24(土) 12:51:07.68ID:d7+fd25J0
>>272
そういう事言い出すと「関数名と機能が一致してる保証がゼロ」や「クラスメンバの隠蔽が完璧である保証がゼロ」などといくらでも難癖を付けれるナリ
ヒューマンエラーを理由に不要と結論付けるのならあらゆるコーディング規約が不要という結論になってしまう、これはいけない
命名規則は可読性の向上に結びつくものでなければならない、規約を違反する事で起きるトラブルはプログラマ側の責任、それは分かるよね?
0283デフォルトの名無しさん (ワッチョイ 2f93-IXLF)
垢版 |
2018/02/24(土) 17:03:03.20ID:agv5rOmv0
>>276 >>282
両者は共存不可能な対立概念ではないけどね。

細かいことを言わせてもらえば、
「ハンガリアンとポリッシュ」か「ハンガリーとポーランド」と
並べてくれた方が座りがいい気もするけど…。
「ハンガリアン記法とポーランド記法」だとあまり気にならない不思議。
0285デフォルトの名無しさん (ワッチョイ 70b3-Tnpk)
垢版 |
2018/02/25(日) 14:16:53.97ID:8l5JrV0a0
>>266
名前付き引数イディオムとenable_if<is_same<...>::value>が最強と言うことだな

※プログラマが、使用者が型を間違えないようにと気を使うのが正しいなら、間違えたらコンパイルエラーになるこれが最強だろ?
0286デフォルトの名無しさん (ワッチョイ ba12-SJjx)
垢版 |
2018/02/25(日) 14:35:24.31ID:zhzj1IkW0
>>277
ちげえんだよんぁ
可読性じゃねえんだよ

>>268を見てみろよ、
読む時じゃなくて書く時のヒューマンエラーだ
なんで入り込んだのか全く分からんようなミステイクだ
プログラミングが工業的生産の一種なら、その手のヒューマンエラーは無い方がいい

で、改めて>>268を見てみると、「可読性」があってプレフィクスの間違いに気付いてはいるものの、
そもそも書く段でなんで間違えたのか、それが全く分からない
他人はおろか本人すらも自覚できない謎の理由でプレフィクスを間違えてる(これがヒューマンエラーなんだけどな)

なんで、後だしジャンケンだと、「プレフィクスが最初から無ければ、間違いも発生しえなかった」、とも言える

もしかすると、書く時に間違える/読む時に間違える の比率を考えると、ハンガリアン記法は書く時に間違えやすいが読むときに間違いにくい……のトレードオフなだけかもしれん
要するに、可読性と生産性のトレードオフだけなんじゃあねえのか?
それに、読む時のヒューマンエラーと書く時のヒューマンエラーをわざと混同してるのはいただけない
0290デフォルトの名無しさん (ワッチョイ 8abd-2pQG)
垢版 |
2018/02/25(日) 19:14:43.19ID:4jIr3vvu0
>>288
func()が常に1画面に収まって1万行の関数とかでありえないという根拠は

>>289
テンプレート定義時の引数に対して引数内容固有の命名が難しいのは
ハンガリアンに限ったことではないからハンガリアンに対する批判になんね

テンプレート批判論者には考える力がないのかね…
0292デフォルトの名無しさん (ワッチョイ df7f-x4Or)
垢版 |
2018/02/25(日) 19:29:08.16ID:s+qaK1zS0
テンプレートに対してはハンガリアンは全くの無力だよなあ
一貫性の観点からやっぱりハンガリアンは無い方がいいわ
0294デフォルトの名無しさん (ワッチョイ 0637-rG1w)
垢版 |
2018/02/25(日) 20:11:05.52ID:fbPK05Px0
そもそも関数が長い場合は型情報を持たすのもありだよな
システムハンガリアンをやめさせようとして先に関数を短くしなきゃだめだなと追う結論に至って放置した
0300デフォルトの名無しさん
垢版 |
2018/02/25(日) 23:57:37.89
>>299
dwをiに置換するだけだからリファクタリングが楽っていう意味?
0307デフォルトの名無しさん (ワッチョイ 8a05-x4Or)
垢版 |
2018/02/26(月) 04:56:46.87ID:lxlU26hn0
>>298
おまえは間違いなく1万行と書いた
その史実を誤魔化すことはできない

「ありえないという根拠は」という問いを反論として用いるのは
俺が「ありえない」と言った(事実と違うが)ことが
おまえが「ありうる」と思っているのと違ったからだろう

いずれにせよ「アホかおまえは」にふさわしいハチャメチャだな
0309デフォルトの名無しさん
垢版 |
2018/02/26(月) 08:09:57.39
>>307
史実とか言っちゃうのって。。。
0315デフォルトの名無しさん (スップ Sdc4-aBV2)
垢版 |
2018/02/26(月) 11:21:30.74ID:mt/mMzV6d
間違えると大変だからハンガリアンを使ってはならないんだよ
偽の情報に頼るんではなくて元を逐一確かめないと
0317デフォルトの名無しさん (ワッチョイ 520e-MTlB)
垢版 |
2018/02/26(月) 11:36:50.47ID:TvC1o7QC0
>>315
不一致が存在しない事が保証されてれば問題無いんやな
そういう事ならつまり変数宣言とプレフィックスが全て一致してるかチェックするスクリプトとかがあれば満足って事でええんか?
0318デフォルトの名無しさん (アウアウカー Sa11-2orQ)
垢版 |
2018/02/26(月) 11:38:09.46ID:n/n1Eejna
>>316
ポインタも必要に応じて使うけど、メモリ管理の煩雑さとミスの危険性を避けるために参照やスマートポインタやコンテナ、イテレータなど他に適切な物がある時はなるべくそちらを使うのが流儀かな。
0319デフォルトの名無しさん (ワッチョイ 8a05-x4Or)
垢版 |
2018/02/26(月) 11:51:17.55ID:lxlU26hn0
>>316
デフォ・・・まあ、そう言えなくもないか
参照でもポインタでもどっちでもいい用途には参照
ポインタでしかできないことはNULLに++や絶対番地指定
参照でしかできないことは一時オブジェクトやコピコン類
0322デフォルトの名無しさん (ワッチョイ df7f-x4Or)
垢版 |
2018/02/26(月) 12:21:09.58ID:W3q5coR10
グーグル規約だと書き込む引数は参照ではなくポインタにしろってなってる
でも標準ライブラリが普通に参照で書き込んでるので意味ないかなと思う
0327デフォルトの名無しさん (アウーイモ MM3a-QuQl)
垢版 |
2018/02/26(月) 18:25:47.85ID:aHz4HBvIM
ローカルで宣言したunique_ptrを他のメソッドに渡してデータをつめたいばあいってどういう引数で渡せば良いの?
unique_ptr<Hoge> ptr(new Hoge);
hogehoge(ptr);

Hogehoge::hoge(const unique_ptr<Hoge>& ptr){
ptr->aaa = 123;
}

これでいける?
なんかウェブサイトみてると&&二つとかあったりするの見かけて混乱してきた
■ このスレッドは過去ログ倉庫に格納されています

ニューススポーツなんでも実況