次スレを立てる時は本文の1行目に以下を追加して下さい
!extend:on:vvvvv:1000:512
C++に関する質問やら話題やらはこちらへどうぞ。
ただし質問の前にはFAQに一通り目を通してください。
IDE (VC++など)などの使い方の質問はその開発環境のスレにお願いします。
前スレ
C++相談室 part129
http://echo.2ch.net/test/read.cgi/tech/1483940967/
このスレもよろしくね。
【初心者歓迎】C/C++室 Ver.100【環境依存OK】
http://echo.2ch.net/test/read.cgi/tech/1478440682/
■長いソースを貼るときはここへ。■
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
C++相談室 part130 [無断転載禁止]©2ch.net
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん 転載ダメ©2ch.net (ワッチョイ f37a-QmV0)
2017/03/31(金) 08:47:49.65ID:UkLjKqcm081デフォルトの名無しさん (ワッチョイ 72cd-8Vmj)
2017/04/08(土) 21:38:17.52ID:J+fRzcYw0 クソライブラリを使うときにexternないと困るな
>>80
例えば <cstdio> の FILE *stdout とか
外部のライブラリの中の静的変数へのプロトタイプとして
FILE *stdout;
て書くと多分そのモジュールに stdout が確保されてしまうんじゃないかな?
関数は
int f();
だけで実体がないのだったらプロトタイプだとわかるけれども
変数は実体を伴うのか参照なのかを区別できない気がする
関数だけ提供するライブラリが存在するのは理解できる
例えば <cstdio> の FILE *stdout とか
外部のライブラリの中の静的変数へのプロトタイプとして
FILE *stdout;
て書くと多分そのモジュールに stdout が確保されてしまうんじゃないかな?
関数は
int f();
だけで実体がないのだったらプロトタイプだとわかるけれども
変数は実体を伴うのか参照なのかを区別できない気がする
関数だけ提供するライブラリが存在するのは理解できる
83デフォルトの名無しさん (ワッチョイ 138f-+TA9)
2017/04/08(土) 21:56:34.32ID:LBU0hU+r0 >>75
つ__cplusplus
つ__cplusplus
84デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/08(土) 23:26:49.13ID:TFmwEDa6r externの必要性をとうとう理解してしまったQ
それに対し相変わらずコミュ障のもう一人のクソコテ
それに対し相変わらずコミュ障のもう一人のクソコテ
85デフォルトの名無しさん (アウアウイー Sa97-lIlP)
2017/04/08(土) 23:36:29.56ID:8P1QJwbCa >>83
#ifdef __cplusplus
#define _static
#define _extstatic extern
namespace {
#else
#define _static static
#define _extstatic static
#endif
_extstatic struct A a[];
_static struct A b[] = {{"1st in b[]", a}, {"2nd in b[]", a+1}};
_static struct A a[] = {{"1st in a[]", b}, {"2nd in a[]", b+1}};
#ifdef __cplusplus
}
#endif
まぁ、確かにこんだけ書けばCでもC++でも無警告でコンパイル通ったけど、
まぁ面倒ですこと(゚д゚)!
#ifdef __cplusplus
#define _static
#define _extstatic extern
namespace {
#else
#define _static static
#define _extstatic static
#endif
_extstatic struct A a[];
_static struct A b[] = {{"1st in b[]", a}, {"2nd in b[]", a+1}};
_static struct A a[] = {{"1st in a[]", b}, {"2nd in a[]", b+1}};
#ifdef __cplusplus
}
#endif
まぁ、確かにこんだけ書けばCでもC++でも無警告でコンパイル通ったけど、
まぁ面倒ですこと(゚д゚)!
86デフォルトの名無しさん (ワッチョイ 7f8c-7E04)
2017/04/08(土) 23:39:18.99ID:bfo0YVHI0 >>85
わざわざc使わなくてもc++だけでよかでしょ?
わざわざc使わなくてもc++だけでよかでしょ?
87デフォルトの名無しさん (ワッチョイ cf7a-02AM)
2017/04/09(日) 00:00:11.10ID:cP8aqgv30 Cでも使いたい人には自分でラッパー作ってくれと言ってるわ
88デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/09(日) 00:52:09.49ID:djBIOydUr89デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/09(日) 01:02:23.00ID:djBIOydUr90片山博文MZ ◆T6xkBnTXz7B0 (スププ Sd92-+G+c)
2017/04/09(日) 07:01:35.78ID:qFsmFYyfd わっしょい、わっしょい
91片山博文MZ ◆T6xkBnTXz7B0 (スププ Sd92-+G+c)
2017/04/09(日) 07:08:55.81ID:qFsmFYyfd 自分の理解できないことを、何でもコミュ症で片付けるやつ、嫌い。
92片山博文MZ ◆T6xkBnTXz7B0 (スププ Sd92-+G+c)
2017/04/09(日) 07:13:22.07ID:qFsmFYyfd 言語障害って日本語があるのに、何で意味不明な略したりするのかな。臆病者だから?
>>84
ところが C には仮定義というものがあって,仮定義しておけば静的変数を共有できるんだよ
だから extern は要らない子!と主張できるんだ
ここは C++ だから,仮定義が出来ない前提で話しているだけだよ
君はまだまだ浅いね
ところが C には仮定義というものがあって,仮定義しておけば静的変数を共有できるんだよ
だから extern は要らない子!と主張できるんだ
ここは C++ だから,仮定義が出来ない前提で話しているだけだよ
君はまだまだ浅いね
94デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/09(日) 08:37:34.70ID:djBIOydUr95デフォルトの名無しさん (ワッチョイ 130e-+TA9)
2017/04/09(日) 09:10:41.09ID:A2LIIX7y0 仮定義はリンカが頑張って実現してるんだが
リンカのマップ情報とか見たことないの?
リンカのマップ情報とか見たことないの?
96デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/09(日) 09:37:03.20ID:djBIOydUr なるほど
仮定義というものが何なのか理解していないのでこういうとんちんかんな発言になるのだな
仮定義というものが何なのか理解していないのでこういうとんちんかんな発言になるのだな
97デフォルトの名無しさん (ワッチョイ 130e-+TA9)
2017/04/09(日) 10:11:41.88ID:A2LIIX7y0 それはこっちの台詞だyo
98デフォルトの名無しさん (ワッチョイ cf59-dxaC)
2017/04/09(日) 10:30:05.69ID:elB46Etj0 仮定義ってなんだっけ
extern int a; が複数の翻訳単位にあったら勝手にaの実体が1個できるというやつだっけ;
C++には無いの?(驚愕
extern int a; が複数の翻訳単位にあったら勝手にaの実体が1個できるというやつだっけ;
C++には無いの?(驚愕
>>98
仮定義はリンカにおんぶにだっこしてもらう仕様だよ
extern を書かなくてもいい、というものだ
実体を持たない普通の外部変数と同じように
int evil_global;
とか書くだけでいい、ヘッダに extern int evil_global; と書く必要がなくなる(宣言部分での初期化はできないことに注意)
いやまあ、ちょっと追いきれていないところがあって、まだ俺も浅いのはみとめるが、とりあえず C++ にはないので、みなかったことにしている
議論が続きそうだが俺は参加しないよ
仮定義はリンカにおんぶにだっこしてもらう仕様だよ
extern を書かなくてもいい、というものだ
実体を持たない普通の外部変数と同じように
int evil_global;
とか書くだけでいい、ヘッダに extern int evil_global; と書く必要がなくなる(宣言部分での初期化はできないことに注意)
いやまあ、ちょっと追いきれていないところがあって、まだ俺も浅いのはみとめるが、とりあえず C++ にはないので、みなかったことにしている
議論が続きそうだが俺は参加しないよ
>>94
仮定義は翻訳単位に閉じたとはいいきれないよ
仮定義は翻訳単位に閉じたとはいいきれないよ
101デフォルトの名無しさん (ワッチョイ bf35-D1KF)
2017/04/09(日) 11:04:16.30ID:Cfl4+wb20102デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/09(日) 17:20:17.02ID:djBIOydUr >>98
>複数の翻訳単位にあったら勝手にaの実体が1個
それはQの妄想というやつで仮定義とは別
なおISO/ IEC 9899:2011では未定義動作になっているので仮に実体が一個になっても違反ではない
>複数の翻訳単位にあったら勝手にaの実体が1個
それはQの妄想というやつで仮定義とは別
なおISO/ IEC 9899:2011では未定義動作になっているので仮に実体が一個になっても違反ではない
103デフォルトの名無しさん (ワッチョイ cf59-dxaC)
2017/04/09(日) 19:24:59.42ID:elB46Etj0 「仮定義」でググッたらあったわ;
ttp://docs.embarcadero.com/products/rad_studio/radstudio2007/RS2007_helpupdates/HUpdate4/JA/html/devwin32/tentativedefinitions_xml.html
extern、static、初期化のいずれも無しの変数宣言っぽいものが(関数外のスコープで)複数個現れたとき、
C言語規格の方が高度なことをしてくれるのか
(C++では>>102によると未定義動作とのことなので同じ結果になるかどうかは規格外の仕様に拠る。
しかし上の説明だけでは関数宣言にexternを付ける意味がまだわかんね;
ttp://docs.embarcadero.com/products/rad_studio/radstudio2007/RS2007_helpupdates/HUpdate4/JA/html/devwin32/tentativedefinitions_xml.html
extern、static、初期化のいずれも無しの変数宣言っぽいものが(関数外のスコープで)複数個現れたとき、
C言語規格の方が高度なことをしてくれるのか
(C++では>>102によると未定義動作とのことなので同じ結果になるかどうかは規格外の仕様に拠る。
しかし上の説明だけでは関数宣言にexternを付ける意味がまだわかんね;
104デフォルトの名無しさん (ワッチョイ f6bc-+TA9)
2017/04/09(日) 19:56:25.40ID:9WDYOgp70105デフォルトの名無しさん (ワッチョイ cf59-dxaC)
2017/04/09(日) 20:10:15.00ID:elB46Etj0 いやすまん「規格外の仕様に拠る」はやや誤解して書いてたわ;
下記の通り、未定義動作を含むコードは合法には成り得ず、実行できるかもしれないが、結果は保証されない。(つまり違反
ttp://www.c-lang.org/detail/undefined_behavior.html
>未定義の動作に対して,その状況を無視して予測不可能な結果を返してもよい。
>翻訳時又はプログラム実行時に,文書化された,環境に特有な方法で処理してもよい(診断メッセージの発行を伴っても伴わなくてもよい。)。
>さらに(診断メッセージを出力し)翻訳又は実行を中断してもよい。
ここで、診断メッセージ云々とか「文書化された,環境に特有な方法で処理」とは安全に実行を止めることを意味する
Windowsでアプリのクラッシュ時に出てくるダイアログとか、コアダンプとかがそれにあたる
下記の通り、未定義動作を含むコードは合法には成り得ず、実行できるかもしれないが、結果は保証されない。(つまり違反
ttp://www.c-lang.org/detail/undefined_behavior.html
>未定義の動作に対して,その状況を無視して予測不可能な結果を返してもよい。
>翻訳時又はプログラム実行時に,文書化された,環境に特有な方法で処理してもよい(診断メッセージの発行を伴っても伴わなくてもよい。)。
>さらに(診断メッセージを出力し)翻訳又は実行を中断してもよい。
ここで、診断メッセージ云々とか「文書化された,環境に特有な方法で処理」とは安全に実行を止めることを意味する
Windowsでアプリのクラッシュ時に出てくるダイアログとか、コアダンプとかがそれにあたる
106デフォルトの名無しさん (ワッチョイ cf59-dxaC)
2017/04/09(日) 20:15:29.79ID:elB46Etj0 ていうか最初の疑問に戻るんですが、総合すると、CでもC++でも「extern」 = 「外部リンケージ」、でおkなのでは…
ただ外部リンケージの意味で省略可能だったり、
ANSI Cにおいては「仮定義」に関する仕様が追加されてるから話が複雑化したように見えているだけで、
ただ外部リンケージの意味で省略可能だったり、
ANSI Cにおいては「仮定義」に関する仕様が追加されてるから話が複雑化したように見えているだけで、
107デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/09(日) 20:16:15.29ID:djBIOydUr >下記の通り、未定義動作を含むコードは合法には成り得ず
何というか、「下記」のどこを縦読みするとそうなるんだか
何というか、「下記」のどこを縦読みするとそうなるんだか
108デフォルトの名無しさん (ワッチョイ f6bc-+TA9)
2017/04/09(日) 20:18:42.95ID:9WDYOgp70 >>106
追加じゃなく追認な
追加じゃなく追認な
109デフォルトの名無しさん (ワッチョイ cf59-dxaC)
2017/04/09(日) 20:19:44.66ID:elB46Etj0110デフォルトの名無しさん (ワッチョイ cf59-dxaC)
2017/04/09(日) 20:34:41.52ID:elB46Etj0 >>108
互いに正しく適合する「宣言」と「定義」からなるプログラムにとって「仮定義」の概念は不要なのだから、
この場合何を追認したかというと既存のソースコードにおける「extern」の誤用を追認したとしか考えられないのでは…
つまり言語規格の既存の条項が「追認」されたわけではなく、あくまで条項が「追加」されたんである
(多分「追認」なんて定義もされていないだろうし、
互いに正しく適合する「宣言」と「定義」からなるプログラムにとって「仮定義」の概念は不要なのだから、
この場合何を追認したかというと既存のソースコードにおける「extern」の誤用を追認したとしか考えられないのでは…
つまり言語規格の既存の条項が「追認」されたわけではなく、あくまで条項が「追加」されたんである
(多分「追認」なんて定義もされていないだろうし、
111デフォルトの名無しさん (ワッチョイ 722b-Crua)
2017/04/09(日) 20:52:23.27ID:k8qrPdcw0 >>106
> 総合すると、CでもC++でも「extern」 = 「外部リンケージ」、でおkなのでは…
ちょっと端折り過ぎかな
n3797(C++14) 7.1.1 Storage class specifiers Example:
static int b; // b has internal linkage
extern int b; // b still has internal linkage
> 総合すると、CでもC++でも「extern」 = 「外部リンケージ」、でおkなのでは…
ちょっと端折り過ぎかな
n3797(C++14) 7.1.1 Storage class specifiers Example:
static int b; // b has internal linkage
extern int b; // b still has internal linkage
112デフォルトの名無しさん (ワッチョイ f6bc-+TA9)
2017/04/09(日) 21:03:07.96ID:9WDYOgp70113デフォルトの名無しさん (ワッチョイ f6bc-+TA9)
2017/04/09(日) 21:04:18.72ID:9WDYOgp70 今となっては忸怩たる思いだが
俺は「追認された」張本人の1人であって
俺は「追認された」張本人の1人であって
114デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/09(日) 21:32:38.73ID:djBIOydUr115デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/09(日) 21:52:43.91ID:djBIOydUr116デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/09(日) 22:01:05.39ID:djBIOydUr >103
そのサイトのANSI Cの説明は多分ウソだぞ
同じ内容なはずのISO Cはそんな定義じゃないから
そのサイトのANSI Cの説明は多分ウソだぞ
同じ内容なはずのISO Cはそんな定義じゃないから
117デフォルトの名無しさん (ワッチョイ 138f-+TA9)
2017/04/10(月) 14:43:46.26ID:DheowmrF0 おまえら規格票くらい買うか、せめてドラフトくらい用意しろや
External object definitions
Semantics
If the declaration of an identifier for an object has file scope and an initializer,
the declaration is an external definition for the identifier.
A declaration of an identifier for an object that has file scope without an initializer,
and without a storage-class specifier or with the storage-class specifier static,
constitutes a tentative definition. If a translation unit contains one or
more tentative definitions for an identifier, and the translation unit contains
no external definition for that identifier, then the behavior is exactly as
if the translation unit contains a file scope declaration of that identifier,
with the composite type as of the end of the translation unit, with an initializer equal to 0.
If the declaration of an identifier for an object is a tentative definition and
has internal linkage, the declared type shall not be an incomplete type.
今どき「ANSI C」とか言っちゃってるサイトは眉に唾してかかれ
External object definitions
Semantics
If the declaration of an identifier for an object has file scope and an initializer,
the declaration is an external definition for the identifier.
A declaration of an identifier for an object that has file scope without an initializer,
and without a storage-class specifier or with the storage-class specifier static,
constitutes a tentative definition. If a translation unit contains one or
more tentative definitions for an identifier, and the translation unit contains
no external definition for that identifier, then the behavior is exactly as
if the translation unit contains a file scope declaration of that identifier,
with the composite type as of the end of the translation unit, with an initializer equal to 0.
If the declaration of an identifier for an object is a tentative definition and
has internal linkage, the declared type shall not be an incomplete type.
今どき「ANSI C」とか言っちゃってるサイトは眉に唾してかかれ
118デフォルトの名無しさん (ワッチョイ 138f-+TA9)
2017/04/10(月) 14:44:01.60ID:DheowmrF0 EXAMPLE 1
int i1 = 1; // definition, external linkage
static int i2 = 2; // definition, internal linkage extern
int i3 = 3; // definition, external linkage
int i4; // tentative definition, external linkage
static int i5; // tentative definition, internal linkage
int i1; // valid tentative definition, refers to previous
int i2; // 6.2.2 renders undefined, linkage disagreement
int i3; // valid tentative definition, refers to previous
int i4; // valid tentative definition, refers to previous
int i5; // 6.2.2 renders undefined, linkage disagreement
extern int i1; // refers to pre vious, whose linkage is external
extern int i2; // refers to pre vious, whose linkage is internal
extern int i3; // refers to pre vious, whose linkage is external
extern int i4; // refers to pre vious, whose linkage is external
extern int i5; // refers to pre vious, whose linkage is internal
EXAMPLE 2
If at the end of the translation unit containing
int i[];
the array i still has incomplete type, the implicit initializer causes it to have one element,
which is set to zero on program startup.
int i1 = 1; // definition, external linkage
static int i2 = 2; // definition, internal linkage extern
int i3 = 3; // definition, external linkage
int i4; // tentative definition, external linkage
static int i5; // tentative definition, internal linkage
int i1; // valid tentative definition, refers to previous
int i2; // 6.2.2 renders undefined, linkage disagreement
int i3; // valid tentative definition, refers to previous
int i4; // valid tentative definition, refers to previous
int i5; // 6.2.2 renders undefined, linkage disagreement
extern int i1; // refers to pre vious, whose linkage is external
extern int i2; // refers to pre vious, whose linkage is internal
extern int i3; // refers to pre vious, whose linkage is external
extern int i4; // refers to pre vious, whose linkage is external
extern int i5; // refers to pre vious, whose linkage is internal
EXAMPLE 2
If at the end of the translation unit containing
int i[];
the array i still has incomplete type, the implicit initializer causes it to have one element,
which is set to zero on program startup.
119デフォルトの名無しさん (ワッチョイ 138f-+TA9)
2017/04/10(月) 14:44:21.17ID:DheowmrF0 6.9.2 外部オブジェクト定義
意味規則 オブジェクトの識別子の宣言がファイル有効範囲及び初期化子をもつ場合,その宣言を識別子の外部定義という。
ファイル有効範囲のオブジェクトの識別子を,初期化子を使わず,かつ,記憶域クラス指定子なしか又は記憶域クラス指定子static で宣言する場合,そのオブジェクトの識別子の宣言を仮定義(tentativedefinition)という。
翻訳単位が,ある識別子に対する仮定義を一つ以上含み,かつその識別子に対する外部定義を含まない場合,その翻訳単位に,翻訳単位の終わりの時点での合成型,及び0 に等しい初期化子をもったその識別子のファイル有効範囲の宣言がある場合と同じ規則で動作する。
オブジェクトに対する識別子の宣言が仮定義であり,内部結合をもつ場合,その宣言の型は不完全型であってはならない。
意味規則 オブジェクトの識別子の宣言がファイル有効範囲及び初期化子をもつ場合,その宣言を識別子の外部定義という。
ファイル有効範囲のオブジェクトの識別子を,初期化子を使わず,かつ,記憶域クラス指定子なしか又は記憶域クラス指定子static で宣言する場合,そのオブジェクトの識別子の宣言を仮定義(tentativedefinition)という。
翻訳単位が,ある識別子に対する仮定義を一つ以上含み,かつその識別子に対する外部定義を含まない場合,その翻訳単位に,翻訳単位の終わりの時点での合成型,及び0 に等しい初期化子をもったその識別子のファイル有効範囲の宣言がある場合と同じ規則で動作する。
オブジェクトに対する識別子の宣言が仮定義であり,内部結合をもつ場合,その宣言の型は不完全型であってはならない。
120デフォルトの名無しさん (ワッチョイ 138f-+TA9)
2017/04/10(月) 14:45:14.16ID:DheowmrF0 例1.
int i1 = 1; // 定義,外部結合
static int i2 = 2; // 定義,内部結合
extern int i3 = 3; // 定義,外部結合
int i4; // 仮定義,外部結合
static int i5; // 仮定義,内部結合
int i1; // 正しい仮定義,前の定義を参照する
int i2; // 前に内部結合をもつ定義があるため,結合の不一致が生じ,6.2.2 によって動作は未定義となる
int i3; // 正しい仮定義,前の定義を参照する
int i4; // 正しい仮定義,前の定義を参照する
int i5; // 前に内部結合をもつ定義があるため,結合の不一致が生じ,6.2.2 によって動作は未定義となる
extern int i1; // 外部結合をもつ前の定義を参照する
extern int i2; // 内部結合をもつ前の定義を参照する
extern int i3; // 外部結合をもつ前の定義を参照する
extern int i4; // 外部結合をもつ前の定義を参照する
extern int i5; // 内部結合をもつ前の定義を参照する
例2. 翻訳単位が
int i[];
を含み,その翻訳単位の最後で,配列i が依然として不完全型をもつ場合,配列i は暗黙の初期化子によって一つの要素をもつようにされる。その要素にはプログラム開始時に0 がセットされる。
int i1 = 1; // 定義,外部結合
static int i2 = 2; // 定義,内部結合
extern int i3 = 3; // 定義,外部結合
int i4; // 仮定義,外部結合
static int i5; // 仮定義,内部結合
int i1; // 正しい仮定義,前の定義を参照する
int i2; // 前に内部結合をもつ定義があるため,結合の不一致が生じ,6.2.2 によって動作は未定義となる
int i3; // 正しい仮定義,前の定義を参照する
int i4; // 正しい仮定義,前の定義を参照する
int i5; // 前に内部結合をもつ定義があるため,結合の不一致が生じ,6.2.2 によって動作は未定義となる
extern int i1; // 外部結合をもつ前の定義を参照する
extern int i2; // 内部結合をもつ前の定義を参照する
extern int i3; // 外部結合をもつ前の定義を参照する
extern int i4; // 外部結合をもつ前の定義を参照する
extern int i5; // 内部結合をもつ前の定義を参照する
例2. 翻訳単位が
int i[];
を含み,その翻訳単位の最後で,配列i が依然として不完全型をもつ場合,配列i は暗黙の初期化子によって一つの要素をもつようにされる。その要素にはプログラム開始時に0 がセットされる。
121デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/10(月) 18:45:17.26ID:srG0I8DXr N1570のリンクを貼ったら、真実を知った>>100が傷ついちゃうかも知れないと思って遠慮してた
122デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/10(月) 23:59:41.82ID:srG0I8DXr とりあえずC++のリンケージ仕様でも投下しとくか
http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2017/
ここのN4660(C++17 DIS)の6.5節の段落3〜4あたりだな
http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2017/
ここのN4660(C++17 DIS)の6.5節の段落3〜4あたりだな
123デフォルトの名無しさん (ワッチョイ 138f-+TA9)
2017/04/11(火) 15:06:41.62ID:xAQ0kPvC0 パスいるやん
124デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/11(火) 17:53:37.33ID:gmpvjUS3r まじか
じゃあ同じ内容のN4659で
じゃあ同じ内容のN4659で
126デフォルトの名無しさん (オッペケ Sr57-GJ90)
2017/04/12(水) 22:52:37.49ID:hzellBg9r127デフォルトの名無しさん (ワッチョイ db57-EaKP)
2017/04/13(木) 12:41:59.49ID:NIQ3hjXd0 んだね
128デフォルトの名無しさん (ワッチョイ eb00-AM0K)
2017/04/13(木) 17:14:46.56ID:IqLxmvNO0 moduleが標準入りするのはいつごろよ?ついでにD言語のversionとaliasもパクって完全体になってほしいね
129デフォルトの名無しさん (ワッチョイ eb7a-3MbB)
2017/04/13(木) 18:41:48.04ID:RdwWAERL0 それよりネットワーク関連を標準化しろ
この際asioでも許容
この際asioでも許容
130デフォルトの名無しさん (ワッチョイ 3b32-Lcy7)
2017/04/13(木) 21:28:48.50ID:n9EAyVre0 asioとhttp系の何かつけてくれ
131デフォルトの名無しさん (ワッチョイ eb86-HE/W)
2017/04/15(土) 11:47:11.44ID:BNJEkz/Q0132デフォルトの名無しさん (ササクッテロル Sp6f-cQmk)
2017/04/15(土) 11:52:21.06ID:0ry10bQQp 標準で入ってることが重要なんじゃないかなあ…
133デフォルトの名無しさん (ワッチョイ 1f6b-HE/W)
2017/04/15(土) 11:56:11.76ID:JwQS3cI30 炊飯器用の小さいネットワークライブラリも必要になるんじゃねえの
134デフォルトの名無しさん (ワッチョイ 0f1f-V7Gz)
2017/04/15(土) 12:21:35.22ID:QXvRHshA0 漁師さん用も頼む
135デフォルトの名無しさん (ワッチョイ eb7a-3MbB)
2017/04/15(土) 14:16:17.69ID:/RNhb41k0 外部ライブラリっていうだけでハードル高くなるからな
仕事で使いづらいのはもちろんとしてOSSでも使用者に各ライブラリを掻き集めてもらわないといけなくなるから最小限にしたい
仕事で使いづらいのはもちろんとしてOSSでも使用者に各ライブラリを掻き集めてもらわないといけなくなるから最小限にしたい
136デフォルトの名無しさん (ワッチョイ 1fb2-EaKP)
2017/04/15(土) 21:37:48.57ID:53BEnEdf0 論理積で空集合になったからといって
じゃあ論理和にしろと? 頭悪すぎだろ
じゃあ論理和にしろと? 頭悪すぎだろ
137デフォルトの名無しさん (ワッチョイ eb59-0/8P)
2017/04/15(土) 22:25:04.54ID:D67U9VSC0 静的型付け言語でオブジェクト指向すると
基底クラスにメソッドが集まっていく…
基底クラスにメソッドが集まっていく…
138デフォルトの名無しさん (ワッチョイ efa6-HE/W)
2017/04/15(土) 22:33:53.11ID:uwyLFIA10 それはよくない兆候だよね
139デフォルトの名無しさん (ワッチョイ eb7a-3MbB)
2017/04/15(土) 23:01:12.27ID:/RNhb41k0 何故テンプレートを使わないのか
140デフォルトの名無しさん (ワッチョイ eb59-0/8P)
2017/04/16(日) 01:51:56.03ID:M1nx5OGg0 基底クラスにメソッドが集まっていくのは仕方が無いにしても、
公開する相手別にインターフェースを分けて抽象クラスの多重継承でもしておけば
大きな混乱は避けられる
希ガス
公開する相手別にインターフェースを分けて抽象クラスの多重継承でもしておけば
大きな混乱は避けられる
希ガス
141デフォルトの名無しさん (ワッチョイ 0b75-7bPG)
2017/04/16(日) 03:21:47.75ID:9vBuyRLK0 仕方ないか?
そういう場合大抵は派生先のあのクラスとあのクラスでこれ使うから基底にいれとこうみたいになってis aじゃなくなってる気がする
そういう場合大抵は派生先のあのクラスとあのクラスでこれ使うから基底にいれとこうみたいになってis aじゃなくなってる気がする
142デフォルトの名無しさん (ワッチョイ 3b0d-T+tu)
2017/04/16(日) 10:05:38.55ID:P5/zt8YK0 俺も>>141に一票かな。
基底クラスに集まって来るような関数群は、共通に使うという一点に於いてのみ意味があることが多いんだよね。
と、すると、大抵別クラスとして分離可能になるってケースが多い気が。
つまり、実はhas-aが妥当で、それどころかUMLで言うところの依存関係だけで問題ない事が多いという。
基底クラスに集まって来るような関数群は、共通に使うという一点に於いてのみ意味があることが多いんだよね。
と、すると、大抵別クラスとして分離可能になるってケースが多い気が。
つまり、実はhas-aが妥当で、それどころかUMLで言うところの依存関係だけで問題ない事が多いという。
143デフォルトの名無しさん (ワッチョイ bbf4-aC3X)
2017/04/16(日) 13:02:22.02ID:FhXvPItE0 dynamic_castは悪という間違った考え方が基底に余計なメンバ関数を実装させる原因
144デフォルトの名無しさん (ワッチョイ eb7a-3MbB)
2017/04/16(日) 13:15:07.28ID:cLuVKvb50 dynamic_castが悪いのではなくdynamic_cast使いまくるようなら設計に問題があるのではないかという話なのでは
145デフォルトの名無しさん (ワッチョイ 4b3c-yJ/5)
2017/04/16(日) 14:09:06.37ID:1LAAxzhm0 おっと、Javaを悪く言うのはそこまでだ
146デフォルトの名無しさん (オッペケ Sr6f-xkGs)
2017/04/16(日) 14:12:39.55ID:kL6yOSUfr 144がアスペなのは間違い無い
147デフォルトの名無しさん (ワッチョイ 0b75-7bPG)
2017/04/16(日) 14:49:30.10ID:9vBuyRLK0 144を理解出来ない146が…
148デフォルトの名無しさん (ワッチョイ eb59-0/8P)
2017/04/16(日) 14:53:55.66ID:M1nx5OGg0 知らね
ゼロから設計するならともかく、すでに出来上がった構造に仕様追加がなされた場合、
基底クラスにメソッドを追加する流れになりがち
かつdynamic_castはある意味オブジェクト指向的解決手段と言えるかもしれないが、
静的型付けという枠組み(>137)から逸脱する
ゼロから設計するならともかく、すでに出来上がった構造に仕様追加がなされた場合、
基底クラスにメソッドを追加する流れになりがち
かつdynamic_castはある意味オブジェクト指向的解決手段と言えるかもしれないが、
静的型付けという枠組み(>137)から逸脱する
149デフォルトの名無しさん (ワッチョイ 1fcc-35Q+)
2017/04/16(日) 15:31:42.38ID:Jwa8aGsr0 dynamic_cast と reinterpret_cast が本来の意味と逆だよな
150デフォルトの名無しさん (ワッチョイ bbf4-aC3X)
2017/04/16(日) 22:20:05.54ID:FhXvPItE0 複数インターフェース継承してdynamic_castすればいいところを、基底で取り敢えず全インターフェース重ねてなにもしない実装を定義するみたいなことが多すぎる。
151デフォルトの名無しさん (オッペケ Sr6f-xkGs)
2017/04/16(日) 22:47:27.74ID:kL6yOSUfr >dynamic_cast と reinterpret_cast が本来の意味と逆だよな
訳:ボクは言語障害です
訳:ボクは言語障害です
152デフォルトの名無しさん (ワッチョイ 9f78-T+tu)
2017/04/17(月) 02:47:11.79ID:/ZxvtgP60 >>150
いや、それもなんかおかしいだろ。
いや、それもなんかおかしいだろ。
153デフォルトの名無しさん (ワッチョイ 6b3c-cQmk)
2017/04/17(月) 03:21:23.30ID:GWeDXk7n0 抽象から具体へのキャストって何かもやもやする
SOLID原則のDIPに反するんじゃないかって気もするし
SOLID原則のDIPに反するんじゃないかって気もするし
154デフォルトの名無しさん (ワッチョイ eb92-D+C1)
2017/04/17(月) 07:06:11.59ID:D/VW2xRY0 昔風の継承モデルは最近使わなくなったなあ
テンプレートの方が融通性高い
テンプレートの方が融通性高い
155デフォルトの名無しさん (ワッチョイ 1fcc-35Q+)
2017/04/17(月) 07:43:02.51ID:H8Au7WAd0 は?バカじゃねぇの
156デフォルトの名無しさん (ワッチョイ 9fc3-hp0W)
2017/04/17(月) 07:48:02.60ID:4nIA4vL50 はい
157デフォルトの名無しさん (ワッチョイ 0b75-7bPG)
2017/04/17(月) 08:36:25.34ID:R62eo4r30 dynamic_castするよりはそいつが該当するinterfaceを持ってるか確認するほうがマシだと思う
struct scroll_interface{
virtual bool down(float value)=0;
virtual bool up(float value)=0;
};
struct view{
virtual scroll_interface* scrollable(){return 0;}
};
struct list_view : view{
virtual scroll_interface* scrollable(){return ptr;}
};
if(auto sc = view->scrollable()){
sc->down(1);
}
みたいな感じ
struct scroll_interface{
virtual bool down(float value)=0;
virtual bool up(float value)=0;
};
struct view{
virtual scroll_interface* scrollable(){return 0;}
};
struct list_view : view{
virtual scroll_interface* scrollable(){return ptr;}
};
if(auto sc = view->scrollable()){
sc->down(1);
}
みたいな感じ
158デフォルトの名無しさん (ワッチョイ eb7a-3MbB)
2017/04/17(月) 08:50:40.08ID:bqYXNS3A0 非メンバ関数にできるものはvariant使った方がいいなって感じになってきた
159デフォルトの名無しさん (スップ Sd3f-a7Ro)
2017/04/17(月) 08:54:59.22ID:OwDSFehNd >>157
なんかやだ
なんかやだ
160デフォルトの名無しさん (ワッチョイ 3b37-T+tu)
2017/04/17(月) 08:55:54.12ID:5RBrgFiu0161デフォルトの名無しさん (スプッッ Sd3f-lyFy)
2017/04/17(月) 09:07:38.99ID:qMcNcEsbd RTTIはオプションで切っておきたい
162デフォルトの名無しさん (ワッチョイ 0b75-7bPG)
2017/04/17(月) 09:13:50.45ID:R62eo4r30 >>160
継承関係になくていいというところが違うし(結構大事だと思う)、dynamic_castはダイナミックリンクするライブラリと組み合わせると面倒くさいからなるべく使いたくないんだよね。
継承関係になくていいというところが違うし(結構大事だと思う)、dynamic_castはダイナミックリンクするライブラリと組み合わせると面倒くさいからなるべく使いたくないんだよね。
163デフォルトの名無しさん (スップ Sd3f-a7Ro)
2017/04/17(月) 10:32:14.53ID:OwDSFehNd 依存関係の強さは変わらんよね
164デフォルトの名無しさん (ワッチョイ 1f6b-HE/W)
2017/04/17(月) 12:22:18.70ID:PEkyQsSL0 その「強さ」を具体的に数値化できればな
165デフォルトの名無しさん (ワッチョイ 2bf4-EaKP)
2017/04/17(月) 14:44:09.70ID:YxhJnxLO0 >>157
スクロールできないクラスの中にscroll_interface*を返す関数があってnullptrを返すのか
その論法では絶対にあり得ない機能への問い合わせ関数を膨大な数抱え込むここになるぞ
スクロールできないクラスの中にscroll_interface*を返す関数があってnullptrを返すのか
その論法では絶対にあり得ない機能への問い合わせ関数を膨大な数抱え込むここになるぞ
166デフォルトの名無しさん (ワッチョイ 2bf4-EaKP)
2017/04/17(月) 14:46:29.60ID:YxhJnxLO0167デフォルトの名無しさん (スップ Sd3f-a7Ro)
2017/04/17(月) 16:34:39.13ID:OwDSFehNd QueryInterfaceいやだ
168デフォルトの名無しさん (ワッチョイ eb00-AM0K)
2017/04/17(月) 16:58:00.17ID:rD3LHvJv0 COM設計したやつって基地外だよな
169デフォルトの名無しさん (ワッチョイ 2bf4-EaKP)
2017/04/17(月) 18:04:25.63ID:YxhJnxLO0 APIが単一空間に際限なく増えることへの危機感から
何らか対策を講じるとして、割とまともな答えだと思う
何らか対策を講じるとして、割とまともな答えだと思う
170デフォルトの名無しさん (ワッチョイ 2bf4-EaKP)
2017/04/17(月) 18:05:14.09ID:YxhJnxLO0 GUIDの扱い方が変態的なのがちょっとイヤだけどね
171デフォルトの名無しさん (ワッチョイ eb59-0/8P)
2017/04/17(月) 22:27:32.59ID:ZfEceRxS0 やっぱこれからはAPIが呼び出し元のコードを生成すべき
172デフォルトの名無しさん (ブーイモ MMaf-YOru)
2017/04/17(月) 22:40:09.29ID:KscfyyhaM 呼び出し元のコードは誰が呼び出すんだ
173片山博文MZ ◆T6xkBnTXz7B0 (スフッ Sd3f-L+dC)
2017/04/17(月) 22:43:06.49ID:dVaQYL/0d オバマ元大統領が電話で呼び出してくれるだろう。
174デフォルトの名無しさん (ワッチョイ 6b3c-cQmk)
2017/04/18(火) 00:19:12.10ID:3dyURfCV0 そうなんだ、すごいね
175デフォルトの名無しさん (ワッチョイ 1fcc-35Q+)
2017/04/18(火) 04:24:36.93ID:sGHQhIiJ0 _人人人人人人人人人人人人人人人_
> そうなんだ、すごいね! <
´ ̄^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^ ̄
__、、=--、、 __
/ ・ ゙! /・ `ヽ
| ・ __,ノ (_ ・ |
ヽ、 (三,、, _) /
/ー-=-i'' (____,,,.ノ
|__,,/ |__ゝ
〉 ) ( )
> そうなんだ、すごいね! <
´ ̄^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^ ̄
__、、=--、、 __
/ ・ ゙! /・ `ヽ
| ・ __,ノ (_ ・ |
ヽ、 (三,、, _) /
/ー-=-i'' (____,,,.ノ
|__,,/ |__ゝ
〉 ) ( )
176デフォルトの名無しさん (ワッチョイ db65-EaKP)
2017/04/18(火) 14:33:19.90ID:opmIphTi0 >>171
APIが関数ではなくテンプレートであるべきということか?
APIが関数ではなくテンプレートであるべきということか?
177ich1 (アウアウオー Sabf-d3ae)
2017/04/18(火) 14:56:55.08ID:ZJShoz7Oa https://goo.gl/Y4tSAe
これは嘘でしょ?本当?
これは嘘でしょ?本当?
178デフォルトの名無しさん (ワッチョイ db65-EaKP)
2017/04/18(火) 15:43:43.41ID:opmIphTi0 >>177
スレ違い「生理前の肌荒れナントカ」
スレ違い「生理前の肌荒れナントカ」
179デフォルトの名無しさん (ワッチョイ 6bc8-HE/W)
2017/04/19(水) 00:24:26.42ID:37YtuUfA0 テンプレートに演算子を与えたいのだけど、マクロでやらないとダメよね?
maxとかminとか。
走査するところは共通で、> か < かが違うだけなのだけど。
maxとかminとか。
走査するところは共通で、> か < かが違うだけなのだけど。
180デフォルトの名無しさん (ササクッテロレ Sp6f-cQmk)
2017/04/19(水) 00:50:34.43ID:5KqdfKh3p 比較用のファンクタをテンプレートパラメータにすれば良いだけじゃないの
STLのmapみたいな感じで
STLのmapみたいな感じで
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 「中国人の訪日熱は冷めた」 人気旅行先から日本外れる 14日で自粛呼びかけ1カ月 [蚤の市★]
- 「1800万円の売り上げゼロに…」中国インバウンドに特化の宿の今 [蚤の市★]
- クリスマスの「予定なし」54% [少考さん★]
- 【話題】好きな鍋は?! 「寄せ鍋」「キムチ鍋」「水炊き」「もつ鍋」「豆乳鍋」「ちゃんこ鍋」「ごま坦々鍋」「トマト鍋」 [ひぃぃ★]
- 【STARTO ENTERTAINMENT】SUPER EIGHTの横山裕、フジ『ドッキリGP』ロケで全治2ヶ月の重傷 [Ailuropoda melanoleuca★]
- 地震 [Hitzeschleier★]
- 【実況】博衣こよりのえちえち機動戦士ガンダム逆襲のシャア🧪
- 不動産屋、ついに帰化した日本人まで「内見の段階で」お断りしはじめる [377482965]
- 茶ぁしばこうや···
- J( 'ー`)し「で、アンタなんで働かないの?」 ワイ👶「理由は2つありまして~」🏡
- 日本人億り人、大丈夫なFXで稼ぎまくる… [667744927]
- おさかなさんあつまれえ
