!extend:checked:vvvvv:1000:512
!extend:checked:vvvvv:1000:512
↑同じ内容を3行貼り付けること
次スレは>>980が立てること
無理なら細かく安価指定
※前スレ
C++相談室 part165
https://mevius.5ch.net/test/read.cgi/tech/1698705458/
VIPQ2_EXTDAT: checked:vvvvv:1000:512:: EXT was configured
C++相談室 part166
1sage (ワッチョイ 8732-NXaD)
2025/04/26(土) 10:34:58.41ID:pbPDl6lv02デフォルトの名無しさん (ワッチョイ 1132-NXaD)
2025/04/26(土) 10:36:05.71ID:pbPDl6lv0 仲良く使ってね
3デフォルトの名無しさん (ワッチョイ b501-4ocp)
2025/04/26(土) 11:57:58.29ID:9PQ55tI10 STLでサイズがウンタラカンタラってなくなったんだね
4デフォルトの名無しさん (ワッチョイ 797c-VXNn)
2025/04/26(土) 13:02:57.57ID:90F8pztq0 あれはキチガイが勝手に貼り続けてただけでテンプレでもなんでもない
5デフォルトの名無しさん (ワッチョイ bfda-OmX0)
2025/04/29(火) 19:50:22.01ID:oiFKb7iS0 プログラムの書き方について学ぶためのサンプルコードですが、
CならLinuxGNUやBSDなど山ほどあるけど、C++の場合は定番としてどんなものがありますか?
CならLinuxGNUやBSDなど山ほどあるけど、C++の場合は定番としてどんなものがありますか?
6デフォルトの名無しさん (ワッチョイ 9ff0-8SS3)
2025/04/29(火) 20:44:07.29ID:snW2quW50 C++標準ライブラリ チュートリアル&リファレンス
っていう分厚い本読んどけば大体理解る
っていう分厚い本読んどけば大体理解る
7デフォルトの名無しさん (ワッチョイ b77c-0tm6)
2025/04/29(火) 21:19:32.60ID:d6I4gAkZ0 C++のOSSねえ
有名でコードの質がいい奴だとLLVMか?Clangも読めばコンパイラだから言語の勉強にはなるはず
規範的って意味だとBoostだけど、いきなり勧めるには技巧的で上級者向けすぎやな面白いけどね
あと有名所ならOpenCVだけどあれは汚いから真似してほしくない
有名でコードの質がいい奴だとLLVMか?Clangも読めばコンパイラだから言語の勉強にはなるはず
規範的って意味だとBoostだけど、いきなり勧めるには技巧的で上級者向けすぎやな面白いけどね
あと有名所ならOpenCVだけどあれは汚いから真似してほしくない
8デフォルトの名無しさん (ワッチョイ d7d7-7NrX)
2025/04/29(火) 23:01:06.57ID:LJmfvcqY0 Open CASCADE も汚いのでお勧めしないなぁ
9デフォルトの名無しさん (ワッチョイ b720-xasm)
2025/04/29(火) 23:56:21.35ID:qhqmYF5L0 ライブラリだと各OSに対応するためのコードだったり、ヘッダーオンリーにするためのテクニックだったりで、純粋なC++プログラムの勉強として見るとノイズが多いかもしれない
実は初心者向きの良い教材ってあんまり無いかも?
中級者以上ならBoostなどは勉強になるけど、簡単ではないし
実は初心者向きの良い教材ってあんまり無いかも?
中級者以上ならBoostなどは勉強になるけど、簡単ではないし
10デフォルトの名無しさん (ワッチョイ 9f07-VpId)
2025/04/30(水) 00:21:11.63ID:en7310Kb0 いろいろとフリーダムすぎてなあ そこがいいんだが
たとえば、ゲーム作りたかったら既存のゲームエンジン、とか、
やりたいカテゴリか近いところの、長続きしてるところの読んでみるといいかも
答えになってないが、(自分用であれ仕事であれ)使わされるのが一番早い
たとえば、ゲーム作りたかったら既存のゲームエンジン、とか、
やりたいカテゴリか近いところの、長続きしてるところの読んでみるといいかも
答えになってないが、(自分用であれ仕事であれ)使わされるのが一番早い
11デフォルトの名無しさん (ワッチョイ bf79-FBhq)
2025/04/30(水) 00:58:19.68ID:TMleEpRy0 Windowsの電卓は平易で初心者向きかも
Google系も平易な印象だけど、Googleは独自ユーティリティを多用しがちなのが難点
Google系も平易な印象だけど、Googleは独自ユーティリティを多用しがちなのが難点
12はちみつ餃子 ◆8X2XSCHEME (ワッチョイ b732-Dk0z)
2025/04/30(水) 09:16:57.03ID:THYm3xdc0 C++ は言語として特定のスタイルを強制しないという方針を持っているからプロジェクトによって構成の仕方は全く違う。
適当な数個のプロジェクトを見ても数個のスタイルがわかるというだけでしょ。
どれが良いかとか言ってないでたくさん見るしか仕方ないんじゃないかな。
入門書とかいくつかの設計指南系の本くらいは読んでる?
理念抜きで結果として出来上がってるコードを見てもわけがわからんと思う。
本はたくさん読んだほうが良い。
それと C++ は今は三年ごとに規格の改定がある。
どの版を想定するかでもかなり違う。
特に大きなターニングポイントになってるのは C++11 と C++20 だと思う。
最新の GCC で特に指定しなければ C++17 として解釈されるのでこのあたりが現在の普通という感じなはず。
適当な数個のプロジェクトを見ても数個のスタイルがわかるというだけでしょ。
どれが良いかとか言ってないでたくさん見るしか仕方ないんじゃないかな。
入門書とかいくつかの設計指南系の本くらいは読んでる?
理念抜きで結果として出来上がってるコードを見てもわけがわからんと思う。
本はたくさん読んだほうが良い。
それと C++ は今は三年ごとに規格の改定がある。
どの版を想定するかでもかなり違う。
特に大きなターニングポイントになってるのは C++11 と C++20 だと思う。
最新の GCC で特に指定しなければ C++17 として解釈されるのでこのあたりが現在の普通という感じなはず。
13デフォルトの名無しさん (アウアウウー Sa1b-Dl8r)
2025/04/30(水) 09:52:26.68ID:uCqRd3Swa >>5
wxWidgets
wxWidgets
14デフォルトの名無しさん (ワッチョイ b720-xasm)
2025/04/30(水) 12:58:39.49ID:8LRHZRl/0 Windows … というか Visual Studio だと今でもデフォルトは C++14 なんだよな
機能的には C++23 まで使えるのに
機能的には C++23 まで使えるのに
15デフォルトの名無しさん (ワッチョイ afaa-hOut)
2025/05/04(日) 16:06:14.75ID:/Tm3kYwr0 初心者スレないんですまん。
C++でvectorとsetで同じことやらすのってどうやるの?
cout << vec << endl;
cout << st << endl;
を共通で書きたいんだけど、
template?の書き方がわかんないの
C++でvectorとsetで同じことやらすのってどうやるの?
cout << vec << endl;
cout << st << endl;
を共通で書きたいんだけど、
template?の書き方がわかんないの
16はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/04(日) 18:28:39.39ID:w7r9Yiaa0 >>15
きちんと諸々に配慮しようとすると面倒なんだけど本当にそれが出来ればよいだけならこんな感じで出来なくはない。
https://wandbox.org/permlink/2CaqGO3tiB7G9tCZ
きちんと諸々に配慮しようとすると面倒なんだけど本当にそれが出来ればよいだけならこんな感じで出来なくはない。
https://wandbox.org/permlink/2CaqGO3tiB7G9tCZ
1715 (ワッチョイ afaa-hOut)
2025/05/05(月) 16:19:33.69ID:WDPor1X6018はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/05(月) 17:57:32.37ID:7tS1Ts+e0 >>17
まさに「諸々に配慮」と述べた部分がそれでね……。
ここで定義した operator<< と元からある operator<< の両方が char を受け取ることが可能なので
どちらを呼び出すべきか曖昧なオーバーロード (ambiguous overload) になってしまっている。
ちゃんとやる場合はここで定義する operator<< が受け取れるのはコンテナに限定しなければならない。
型に制約を付ける真っ当な方法が入ったのは C++20 からなのでそれ以前の C++ でやろうとすると回りくどいんだよ。
C++11 でなるべく簡素に書くとしたらこんな感じかな。
https://wandbox.org/permlink/Hli0dW7vNwSICQmp
まさに「諸々に配慮」と述べた部分がそれでね……。
ここで定義した operator<< と元からある operator<< の両方が char を受け取ることが可能なので
どちらを呼び出すべきか曖昧なオーバーロード (ambiguous overload) になってしまっている。
ちゃんとやる場合はここで定義する operator<< が受け取れるのはコンテナに限定しなければならない。
型に制約を付ける真っ当な方法が入ったのは C++20 からなのでそれ以前の C++ でやろうとすると回りくどいんだよ。
C++11 でなるべく簡素に書くとしたらこんな感じかな。
https://wandbox.org/permlink/Hli0dW7vNwSICQmp
19デフォルトの名無しさん (ワッチョイ a701-uYIY)
2025/05/06(火) 12:29:11.51ID:tCHDdC6b0 >template <class T>
>auto operator<<(std::ostream& os, const T& container_object)
> -> typename std::enable_if<!!sizeof(begin(std::declval<T>()) != end(std::declval<T>())), std::ostream&>::type {
横から何じゃこりゃw
>auto operator<<(std::ostream& os, const T& container_object)
> -> typename std::enable_if<!!sizeof(begin(std::declval<T>()) != end(std::declval<T>())), std::ostream&>::type {
横から何じゃこりゃw
20はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-6RYV)
2025/05/06(火) 12:35:30.96ID:SvTeM3j90 declval は要らんな。
もっとキッチリしたほうがいいのか簡素にしようか迷ってちょっと変な感じになってる……。
もっとキッチリしたほうがいいのか簡素にしようか迷ってちょっと変な感じになってる……。
21デフォルトの名無しさん (ワッチョイ a701-uYIY)
2025/05/06(火) 13:03:38.40ID:tCHDdC6b022はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/06(火) 13:42:19.73ID:SvTeM3j90 >>21
関数名の前に auto を書くと仮引数の後ろに返却値の型を書けるようになる。
つまり -> から { までのところに書いてるのが返却値の型。
従来の書き方では関数の仮引数を返却値の型を決定する文脈では使えないというルールがある。
たとえば
template<class T> decltype(e) foo(const T& e) {return e;}
というようなことは出来ない。 ここで e を参照することは出来ない。
後置では返却値の型を書くところで仮引数を使ってかまわない。
template<class T> auto bar(const T& e) -> decltype(e) {return e;}
ってのはアリ。
この場合の auto は返却値の型を後置するというマークってことね。
後置にする必要がなくても後置で一貫させてるプロジェクトもたぶん結構ある。
auto がこのような用途で使えるようになったのは C++11 からなのでもう結構浸透してると思うんだけど、全く見たことないの?
!! は ! をふたつ並べてるだけ。 bool にキャストする代わりに使うイディオムなんだけど見づらいからやめたほうがよいという人も多い。
関数名の前に auto を書くと仮引数の後ろに返却値の型を書けるようになる。
つまり -> から { までのところに書いてるのが返却値の型。
従来の書き方では関数の仮引数を返却値の型を決定する文脈では使えないというルールがある。
たとえば
template<class T> decltype(e) foo(const T& e) {return e;}
というようなことは出来ない。 ここで e を参照することは出来ない。
後置では返却値の型を書くところで仮引数を使ってかまわない。
template<class T> auto bar(const T& e) -> decltype(e) {return e;}
ってのはアリ。
この場合の auto は返却値の型を後置するというマークってことね。
後置にする必要がなくても後置で一貫させてるプロジェクトもたぶん結構ある。
auto がこのような用途で使えるようになったのは C++11 からなのでもう結構浸透してると思うんだけど、全く見たことないの?
!! は ! をふたつ並べてるだけ。 bool にキャストする代わりに使うイディオムなんだけど見づらいからやめたほうがよいという人も多い。
23デフォルトの名無しさん (ワッチョイ a701-uYIY)
2025/05/06(火) 14:29:32.39ID:tCHDdC6b024はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/06(火) 16:07:03.30ID:SvTeM3j90 >>23
> !!も分かりました(g++-12はなしで通ります)
非型テンプレートパラメータで size_t (sizeof の結果) から bool への変換 (縮小変換) は認められていないはず……
……と思ったらこれには例外があってコンパイル時計算の文脈で実際には情報が欠落しないなら OK。
つまり整数の 0 か 1 のときに限り (型の大きさとしては小さくなる変換であっても) bool に変換が可能。
> !!も分かりました(g++-12はなしで通ります)
非型テンプレートパラメータで size_t (sizeof の結果) から bool への変換 (縮小変換) は認められていないはず……
……と思ったらこれには例外があってコンパイル時計算の文脈で実際には情報が欠落しないなら OK。
つまり整数の 0 か 1 のときに限り (型の大きさとしては小さくなる変換であっても) bool に変換が可能。
25デフォルトの名無しさん (ワッチョイ 1279-k14q)
2025/05/06(火) 17:28:20.12ID:GbYxwNEQ0 非0ならtrueやないんか
26はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/06(火) 18:05:53.77ID:SvTeM3j90 >>25
せやで。 こういうときは変換されない。
template<bool num>
class foo {};
int main(void) {
foo<2> bar;
}
通常の暗黙の変換で許されていても非型テンプレートパラメタでは縮小変換はされないので↓みたいなのも駄目。
template<unsigned char num>
class foo {};
int main(void) {
foo<1000> bar;
}
せやで。 こういうときは変換されない。
template<bool num>
class foo {};
int main(void) {
foo<2> bar;
}
通常の暗黙の変換で許されていても非型テンプレートパラメタでは縮小変換はされないので↓みたいなのも駄目。
template<unsigned char num>
class foo {};
int main(void) {
foo<1000> bar;
}
2715 (ワッチョイ afaa-hOut)
2025/05/06(火) 18:35:49.00ID:jhNAw2EC028デフォルトの名無しさん (アウアウウー Sac3-7Zak)
2025/05/06(火) 18:36:01.85ID:nZOyiL0Ra enable_ifは便利だけど使ったら負け感が半端無い
29はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/06(火) 19:26:25.22ID:SvTeM3j90 この場合は enable_if は本来の意味で使ってないしな。
30はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/06(火) 20:07:39.20ID:SvTeM3j90 >>27
こんな感じかな。
https://wandbox.org/permlink/IgEx8yRTGMZ2qr6U
C++20 からはイテレータの概念も再編されて range という概念で扱うのが好ましいということになり、コンテナは range の一種だったことになった。
コンテナの中のここからここまでという範囲を表すものを中心にした考え方で、コンテナ自身も range だし、コンテナの除き窓のような view も range 。
Rust とか Go で言うスライスみたいなもん。
で、テンプレート引数として受け取った T が std::ranges::range の制約を満たすものなんやでという制約を入れることによってそうじゃないものはマッチしないように出来るし、
他の operator<< の候補にマッチするものがあるのならそっちが選ばれるようになる。
こんな感じかな。
https://wandbox.org/permlink/IgEx8yRTGMZ2qr6U
C++20 からはイテレータの概念も再編されて range という概念で扱うのが好ましいということになり、コンテナは range の一種だったことになった。
コンテナの中のここからここまでという範囲を表すものを中心にした考え方で、コンテナ自身も range だし、コンテナの除き窓のような view も range 。
Rust とか Go で言うスライスみたいなもん。
で、テンプレート引数として受け取った T が std::ranges::range の制約を満たすものなんやでという制約を入れることによってそうじゃないものはマッチしないように出来るし、
他の operator<< の候補にマッチするものがあるのならそっちが選ばれるようになる。
3115 (ワッチョイ afaa-hOut)
2025/05/06(火) 21:47:53.45ID:jhNAw2EC0 >>30
ありがとうございます。
rangeはときどき見てたんですけど、ぱっと見あんまり必要性がわからなかったんですけど、こういう理由があったんですね。
これから時間があるときは、rangeを意識して書きたいと思います。
ありがとうございました
ありがとうございます。
rangeはときどき見てたんですけど、ぱっと見あんまり必要性がわからなかったんですけど、こういう理由があったんですね。
これから時間があるときは、rangeを意識して書きたいと思います。
ありがとうございました
32デフォルトの名無しさん (ワッチョイ df01-7ORQ)
2025/05/07(水) 09:06:41.19ID:pa9hjTXM0 >>29
ostreamあんま詳しくないので本来の意味じゃないってのが良くわからんかった
コンテナでなければ弾くようにしてるんだと思うけどsizeofで括ってるのは式自体が評価されないようにするため?
ostreamあんま詳しくないので本来の意味じゃないってのが良くわからんかった
コンテナでなければ弾くようにしてるんだと思うけどsizeofで括ってるのは式自体が評価されないようにするため?
33はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/07(水) 09:38:53.26ID:jrPMMEx+0 >>32
そう。
実態としては sizeof の中の式が成立するかどうかだけが判定基準になってる。
sizeof が 0 を返すことはあり得ないわけだし sizeof の中の式が成立しないなら enable_if で判定する以前に弾かれるわけなので enable_if は判定の役に立ってない。
式を書く場所があるならなんでもよかったんだけど最終的には ostream& になってもらわないといけないので enable_if が楽だったというだけ。
そう。
実態としては sizeof の中の式が成立するかどうかだけが判定基準になってる。
sizeof が 0 を返すことはあり得ないわけだし sizeof の中の式が成立しないなら enable_if で判定する以前に弾かれるわけなので enable_if は判定の役に立ってない。
式を書く場所があるならなんでもよかったんだけど最終的には ostream& になってもらわないといけないので enable_if が楽だったというだけ。
34デフォルトの名無しさん (ササクッテロラ Spc7-7ORQ)
2025/05/07(水) 09:53:44.11ID:zHwjwbR2p あーなるほど、意味がわかった
ありがとう
ありがとう
35デフォルトの名無しさん (ワッチョイ 1202-mpUa)
2025/05/07(水) 22:31:24.20ID:OFqp/W1O0 vectorって、
宣言時に、要素数と初期値を設定できないっけ?
気持ちとしては、、
↓
vector<int> my_data(3) = { 6, 8, 44 };
宣言時に、要素数と初期値を設定できないっけ?
気持ちとしては、、
↓
vector<int> my_data(3) = { 6, 8, 44 };
36はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/07(水) 22:42:31.19ID:jrPMMEx+037デフォルトの名無しさん (ワッチョイ a701-uYIY)
2025/05/07(水) 22:57:31.27ID:F57QgFhN038はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/07(水) 23:14:20.16ID:jrPMMEx+0 >>35
与えている要素の個数に間違いがないことを確実にしたいというのが目的だとしたらこういう関数を定義するのはどうだろう。
https://wandbox.org/permlink/QBu2dsYRUkrMmLzC
与えている要素の個数に間違いがないことを確実にしたいというのが目的だとしたらこういう関数を定義するのはどうだろう。
https://wandbox.org/permlink/QBu2dsYRUkrMmLzC
39デフォルトの名無しさん (ワッチョイ 1202-mpUa)
2025/05/07(水) 23:14:51.64ID:OFqp/W1O040はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/07(水) 23:25:35.43ID:jrPMMEx+0 >>39
文法の一貫性としてということ?
配列をそう定義したときの [3] は型の一部であってコンストラクタに渡す値ではないから……。
配列をそう書けるのが例外的、変則的な措置だと考えるべきだと思う。
文法の一貫性としてということ?
配列をそう定義したときの [3] は型の一部であってコンストラクタに渡す値ではないから……。
配列をそう書けるのが例外的、変則的な措置だと考えるべきだと思う。
41デフォルトの名無しさん (JP 0Hee-L4A6)
2025/05/08(木) 00:57:15.98ID:4oP42WaSH42デフォルトの名無しさん (JP 0Hee-L4A6)
2025/05/08(木) 01:50:59.67ID:4oP42WaSH はちみつさんはC++仕様策定委員なの?
委員会でそんな発言されたら困るよ。
今さらtraitsみたいなトリック
使いたくないよ。
委員会でそんな発言されたら困るよ。
今さらtraitsみたいなトリック
使いたくないよ。
43はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-6RYV)
2025/05/08(木) 02:01:35.71ID:aAWkv5hi044デフォルトの名無しさん (ワッチョイ 1202-mpUa)
2025/05/08(木) 03:34:36.76ID:JGiTQ1yK045はちみつ餃子 ◆8X2XSCHEME (ワッチョイ 6332-x8bn)
2025/05/08(木) 08:59:22.62ID:aAWkv5hi0レスを投稿する
ニュース
- 橋下徹氏「この喧嘩は日本の完敗」 台湾有事答弁めぐる外務省局長訪中で指摘「中国に怒られてご説明に伺った日本と見られる」 [muffin★]
- 【日本大使館】中国在留邦人は安全確保を [ぐれ★]
- 【外国人問題】小野田紀美担当相「不法就労や不法滞在は許さない」 [シャチ★]
- 【野球】井端監督 大谷翔平、山本由伸らのWBCへの参加 「1日も早く返事ほしい」「待っててといっても、国内組が遅くなってしまう」★3 [冬月記者★]
- 習政権、高市首相への態度硬化 台湾有事発言で連日非難 中国 ★10 [ぐれ★]
- 東京株式市場 インバウンド関連株が下落 中国政府の渡航自粛要請で [バイト歴50年★]
- 有識者「高市総理が発言を撤回したり、辞職するしかないと言っている人は、それで日中関係が今まで通りになると思ってる?」 [834922174]
- もしかして安倍晋三て有能だった?ネトウヨを掌握しつつ韓国、中国、ロシアへの売国をバレないようにやってたし [472617201]
- 高市コイン、155円突破wwwwwwwwww [246620176]
- おじゃる丸をまったり待機するスレ🏡
- 高市早苗の中国問題、「オーバーツーリズムが解消されてウザい中国人が消えるから日本の勝ち」という風潮になってしまう [562983582]
- 【悲報】有名ウヨ論客、「現実的に考えて中国と仲直りするしかなくね?」と言ったら野良ウヨから総叩きにあう [856698234]
