C++相談室 part136
■ このスレッドは過去ログ倉庫に格納されています
次スレを立てる時は本文の1行目に以下を追加して下さい。
!extend:on:vvvvv:1000:512
C++に関する質問やら話題やらはこちらへどうぞ。
ただし質問の前にはFAQに一通り目を通してください。
IDE (VC++など)などの使い方の質問はその開発環境のスレにお願いします。
前スレ
C++相談室 part135
https://mevius.5ch.net/test/read.cgi/tech/1522495206/
このスレもよろしくね。
【初心者歓迎】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 昨今の潮流はオブジェクト指向と関数型のハイブリッド
この二つをどう摺り合わせるか、どの言語もまだ明確な回答が出ていない
もちろんC++も アクセス権つき構造体とユニファイドコールシンタックスで疎結合オブジェクト指向だ。
と考えたのだが、ユニファイドコールシンタックスが死んでしまった。 ifdefできるだけなしで
どんなコンパイラでも通って同じ動作するコードを書けよ
コレは命令だ お前は本当にそんなにコンパイラを使い分けてるのか? 最低限、実機で間違いなく動いて
シミュレーターで間違いなく動くようにコード書きなさい
コードはいろんな実機をサポートしないといけない
実機ごとにOSも違う ICE上でのみ動作するコード
MIRACLE ON ICE 関数型も40年前からオワコンという現実を見ようよ。
5chのスレも全く伸びない。10年で1スレ消費できないレベル。 スレが伸びないのは難し過ぎるからじゃないのか
オブジェクト指向なんかはニワカが口を挟みやすい
あれやこれやと語ることがあると自転車置き場のごとくスレが伸びるんだよ 数学板とか物理板の質問スレで2chに失望し、それ以降2chで理系関連の質問はしないようにしてる >>532
稀に神回答がつくのを期待するしかないのです クラス/構造体の非静的メンバ変数/関数へのポインタ宣言 ってのを初めて知ったんですが、
これはどういう活用方法があるんでしょうか?
struct S { int data; };
int S::*d = &S::data;
S s1 = {999};
s1.*d; // → 999
s1.*d = 123;
(参考: 改訂第3版 C++ポケットリファレンス p.39)
上の例だと、 s1.data の別名以外の使い道がないように見えます。
長い長い真名の時は局所的に略記できて便利とか?、まさかそれだけですか? なんか昔同僚がメンバ関数へのポインタ使ってて納得した覚えがあるが
なんで納得したのかはもう忘れた >>535
動的に呼び出すメソッドを切り替えたいとかだね〜 >>535
そのとき S が int 型のメンバを持たなくても int S::*d という変数宣言が許される。
(無理矢理な型キャストをしない限りヌルしか入れられないけど。)
つまり、 S がプリミティブな型でなくクラスであるならば、メンバにかかわらず int S::*d は許容されて、
プリミティブな型だったらエラーになる。
この性質を利用して SFINAE で切り替えれば、与えられた型がクラスであるかどうか判定するものを作れる。
それが >>538 の言う is_class の実装に使えるって話ね。
まあ今なら is_class を使えよって話だから普通のプログラマ的にはどうでもいいけど。
回りくどい利用法なんだけど、まあ実際のところ実務の中で必要とする場面はそんなにないから、
この利用法が代表的なものとして紹介するしかない。 初心者の質問に答えていただき有難うございます。
動的にメソッド切り替えは実際に動かして理解できました。
SFNAEで切り替えの方ははコンパイル通る形にはできてませんが概要は理解できました。 メンバ関数ポインタがあの形になってるのはまあわかるから
変数もおまけで同じ形にそろえたのかな > 実務の中で必要とする場面はそんなにない
データメンバはともかくメンバ関数へのポインタは必須だろうが >>543
ないと困る局面があるという意味では必須だけどそんな局面は滅多にないって話な >>545
バインダ使うときどうすんだよ
そりゃあエンドユーザーは滅多にというか一生使わんが
そんな話してねえぞ ある必須の用途で必要なら、その用途がいくら狭くて稀であったとしても
それは必要なんだよ メンバ関数ポインタ面倒だから出会ったら大体ラムダでラップしてしまう・・・ std::stack や std::queue に begin() end() clear() などが無いのは何故ですか
begin() end() はともかく clear() は有ったほうが良いと思うのですが >>550
機能を絞っていることが彼らコンテナアダプタの唯一の存在価値なので許してあげてください。 template<class ... Args>
void func1(Args ... args) {
outputs(buf, args...);
}
こういう可変長引数のテンプレートの場合に別のファイルで利用する場合には
どう宣言したらいいの?
void func1(???); >>546
> バインダ使うときどうすんだよ
だからバインダ使いまくるとか覚えたての初心者か
って話な
> そりゃあエンドユーザーは滅多にというか一生使わんが
誰もしてない話を勝手に始めて
> そんな話してねえぞ
とか、ギャグかよ w
>>548
>>545の日本語も理解できないのか? >>554
バインダ使えないアホか
マジになって悪かったな 関数型テンプレートってのは、型でもなしに、実態でもない。不思議な存在だ。
型だとすれば、関数プロトタイプのように繰り返して宣言しても問題ないはずだ
が、そうするとエラーになる。実態かというと、これ自体では何のコードも生成しない。
利用するときに始めてコードが生成される。 unsigned long address;
int dt;
*(char *)&address = dt;
コンパイラエラーにはならないが動作しない。ところが
uint8_t *address ;
*address = dt;
これだと動作する。なぜなんだ? =0x20000;を書き忘れていた。あとは上に同じ。 >>559 俺の環境だと上の方でも動作するみたい。
dtの下位8bitがaddressの下位8bitに格納され、addressの上位24bitは不変。
期待通りと思える。 前者はaddressの最初(または最後)の1byteだけを書き換えようとしているけど、それは意図通りなの?
後者は0x20000番地の値を書き換えようとしてるけど、そこは書き換えてもよい領域なの? おっと、未定義動作がらみで「何が起きても不思議じゃない」かも知れん。
リトルエンディアンの機械での素朴な予想レベルでの「期待通り」ね。 uint8_t *address = 0x20000;
がコンパイル通るわけねえだろ質問したいならちゃんとしろ >>546
c++で閉じてるなら関数ポインタ渡すインターフェイスより、
クラスを継承してメソッド実装させるインターフェイスのが普通だろ。
まあcからの関数ならよくあるが。
>>557
単なる型付マクロだっつーの。 マクロで再帰ができるか!!!!!!!1111!1!11!1!1!
前半は同意
あと関数を単に差し替えたい目的ならファンクタとk そういう事言うとプリプロの怖い人達が来るからやめれ
本物の再帰じゃないけど再帰っぽいことはできるらしいぞ スフィ姉を使った技についてスレッドがあってもいいかもしれない。 「マクロ使う奴はアホ」とか言う奴は、goto文も絶対に使わなそう >>563
damecaseの理由がわからない。
void Test::clear(unsigned long baseadd, unsigned int dt, int leng)
{
#if(okcase)
uint8_t * addp = (uint8_t *)baseadd;
for(int i=0; i<leng; ++i){
*addp++ = dt;
}
#endif
#if(damecase)
unsigned long addp = baseadd;
for(int i=0; i<leng; ++i){
*(char *)&addp++ = dt;
}
#endif
} baseadd=0x20000でダンプすると初期値は全部ffが入っている。
leng=100としてdt=0を書き込むとokcaseはOK100バイト0クリアされる。
damecaseは全く反応しない。 >>566
とおるよ。頭の中でCastしてくれたら >おっと、未定義動作がらみで「何が起きても不思議じゃない」かも知れん。
>リトルエンディアンの機械での素朴な予想レベルでの「期待通り」ね。
どうして?
何処が、どういう理由で未定義なの?
リトルエンディアンが問題というのはバイトオーダーが関係するということ?
1バイトのエリアに代入するのにバイトオーダーが関係するはずはないでしょ。どいういうこと?
char*pのpは1バイトデータのポインタ(アドレス)だよ。代入先が1バイトなのでエンディアンは関係ないと思うが、、、 >>579
strict aliasing ruleでググるか死ぬかどっちか選べ >>576
damecaseの*(char *)&addp++ = dt;
&いるぅ? >>579
「ある型へのポインタの値をキャストで別の型へのポインタとして扱い、
その(キャストで得られた)ポインタに対して * 演算子で格納する」行為自体が
規格で未定義になってるかも知れんてこと。確実じゃないんだけど。
キャストの時点でか、*でアクセスしたときか、格納の時か、
どことは言えないけど何となく未定義クサい感じがする。 ↓addpをインクリメントとか頭悪いの?
*(char *)&addp++ = dt;
unsigned longのaddpをインクリメントしてる
addpはポインタじゃないぞ。。。
きっとバカが動作しないといってるのは
落ちるということではない
動作はするが期待どおりの結果にならないということで間違いない
バカはなにがやりたいのか意味不明 unsigned long addr = 12345678;
char* pByte = &addr;
ならいけるハズ
*pByte++ = dt
で leng が sizeof(unsigned long)/sizeof(char) 回までの繰り返しなら
普通に落ちずに動作するハズ
ばああああああああああああああか
しかいないわこのスレ いやねcすら理解できてないヤツラが
c++とか一億年早い
こんなヤツラがc++でコード組んでるかと思うと
ぞっとするわ。。。
シロウトはおとなしくjavaにしときなさい for(int i=0; i<leng; ++i){
((char *)&addp)[i] = dt;
}
バカ向けのコードを書いてやったぞ
コレでバカにとってはすべて解決
コレがなんのことか分からないなら
もう二度とプログラムなんかやらないほうがいい
センスない、むいてない >>586
strict aliasing ruleでググるか死ぬかどっちか選べ ぐぐったぞ
http://d.hatena.ne.jp/yohhoy/20120220/p1
> 文字型。規格ではchar*, signed char*, unsigned char*が別の何かを指すことが特別に許されています。
> これは文字型がメモリ上の任意のaliasになり得ることを意味します。
どうかしたのか
もうねバカばっかりで困るわマジで
池沼しかいないの? このスレ? ちなみになchar以外で変なメモリアドレス(メモリ上有効なアドレスあっても)の位置からcharより大きいサイズの数値を参照すると
memory wrapの切れ目の問題(つまりwrap over)で
bus errorを普通に起こす計算機がある
このスレにいるようなマヌケたち以外にとっては常識だからな 役に立つ情報ありがとう。
でも、半角カナは止めてね。 >&いらん
コンパイルエラーにはならない。ワーニングにもならん。という事実を書いている。
些末なことで糞ほどワーニングやエラー出すC++だ。ワーニングにならんということは正しい
ということか、コンパイラがアフォかさもなくば、何か別の意味があるということになる。
わかるか? お前にも質問の意味が分かるように、そしてちゃんと回答ができるようにもう一度簡単に書いてやろう。
1.正しい
2.コンパイラがアフォ
3.意図とは別の意味になっている。
さあどれが正解だ。答え見ろ。 >584
はあー、未定義かもしれんて? 未定義ならエラーになるだろ。 >>589
理由を書いてごらん。理由がないと回答にならんよ。 >>585
俺はやらないがそこは問題じゃない。
アドレス値が格納されている正数を1ずつ増分しているだけだ。
>>589
お前は>>576のコードをそれに書き換えて正しく動作すると思ってるのか?
>>582>>583で答えが出てるのに、馬鹿には理解できなかったのだろうな。
俺なら恥ずかしすぎて首吊って死ぬわ。
>>594
4. お前がアフォ なにが書いてごらんだ
バカのくせにえらそうに。。。
addpはアドレスじゃない
で、addpはどこのアドレスをさしてる?
で、なにがインクリメントされてる?
バカにはまだわからないらしいわ、、、
int hoge[10]
int boo = 1234;
char* hogeee = (char*)hoge;
ex1
for (int i = 0; i < 10; ++i) {
*((int*)hogeee) = boo;
hogeee += sizeof(int) / sizeof(char);
}
ex2
for (int i = 0; i < 10; ++i) {
((int*)hogeee)[i] = boo;
}
ex1とex2、この違いわかる?
わからないなら、もうすべてを諦めたほうがいい
オレはオマエを諦める >>>582>>583で答えが出てるのに、馬鹿には理解できなかったのだろうな。
>俺なら恥ずかしすぎて首吊って死ぬわ。
ではその理由を書いてごらん。理由がないと回答にならんよ。理由が説明できないなら試験も受からんだろ。 >で、addpはどこのアドレスをさしてる?
>で、なにがインクリメントされてる?
まず、どこをさしているのか?何がインクリメントされているのか答えてごらん。 致命的に脳ミソが足りないのは理解した
アンリカバブルだ お前は解ったふりをしているだけだよ。言葉にして説明できないならな。 ここまで説明して
なんで同じ結果にならないか
分からないならもうムリだからな
向いてない
諦めなさい
なにごとも諦めが肝心 誤魔化して変なコードを追加するな。問題はこれだ。
unsigned long addp = baseadd;
for(int i=0; i<leng; ++i){
*(char *)&addp++ = dt;
}
このコードが何故動作しないか? それを説明するのが問題なのだ。 多分解っている人なら、直ぐに説明できる筈だ。
分からない人は説明できない。罵るのはさらに愚。 同じ結果にならないことはすでに説明してるからな
アドレスを格納する変数を使わないで同じ結果にしたいならどうすばいいか
まで書いた
それに対する補足説明まで書いた
もうこれ以上書くことはない
ムダ >アドレスを格納する変数を使わないで同じ結果にしたいならどうすばいいか
>まで書いた
>それに対する補足説明まで書いた
思わせぶりな回答を書いて欲しいといっているのではない。頭がいいと思ってほしいのかもしれないが
それでは「思わせぶり」でしかない。説明としてきちんとした形式を備えた自信のある回答を書いてごらん。 >>599
え、なんで?
礼儀を知らないおっさんに教えてやることなんて一つもないよ。
ちな>>597で馬鹿呼ばわりしたのは半角でバカバカ言ってるやつのことなんで。 >608
「教えない」習性の人は成長しない。ということは知っているだろ。習性というくらいだから今に始まったこと
ではない。つまり嘗て勉強を始めた時点ですでに成長はとまっているということだ。 俺は無償でお前等に考え方、回答の方法を教えている。教えることが一番勉強になる。
いままでのところ質問にたいして誰も合格点をあげることができるような回答がない。 addpの値として期待されているのがアドレス値X。&addpは、アドレス値Xを格納している変数addpのアドレス値Y(ポインタの値)。代入によって期待されているのが、アドレスXへのdtの値の格納。
XはYではないから、間違い。 というか&addp++の時点でエラーでるなこれ
コンパイラ何使ってるの? >>612
正に初歩的な質問というものは質問自体に間違いが含まれている可能性がある。
そのことに先ず言及できたのは君が初めてだ。素晴らしい。
質問者が正確に質問できた時点で回答は既になされたも同然だといわれるが今回も
例外ではない。これで終わる。 なめたことをしてくれたな。。。
558 名前:デフォルトの名無しさん (ワッチョイ 469d-mzC7)[] 投稿日:2018年06月30日(土) 08時17分40秒24 [朝] ID:p5lz5e260 [2/19] (PC)
コンパイラエラーにはならないが動作しない。
594 名前:デフォルトの名無しさん (ワッチョイ 469d-mzC7)[] 投稿日:2018年06月30日(土) 22時22分23秒05 [夜] ID:p5lz5e260 [8/19] (PC)
コンパイルエラーにはならない。ワーニングにもならん。という事実を書いている。
(ワッチョイ 469d-mzC7) ID:p5lz5e260
オマエを特定した
震えて眠りなさい ことさらに難しいコードを書いて得意がってる馬鹿がうようよ
1行に詰めるのがプロか?
新入社員が読めないようなコード書いて喜んでいるお前らが
バグを仕込む糞プログラマだわ 有能なプログラマはこんな場所で遊んでいない
暇なプログラマっていうか、仕事が無いプログラマ? プログラマにまともなコード書いてもらうも仕事の一つだからな
まともなコード書いてもらうには
こっちもプログラムが分かってないといけない
日本はウンコみたいな低品質低能のプログラマしかいない
いかに踏みとどまらないといけない最低限の一線のラインを越えさせないようにするか
そこが腕のみせどころになる
このスレみれば分かる通り
日本のプログラマは低学歴低能しかいないことがよく分かるハズ
しかも相手がなにを期待してるかも読みとれない
コミュニケーション能力も著しく低い
こんなのに仕事をお願いするほうも大変だからな
可読性が高いコードを書くことは重要だが
それ以外にもイロイロなものが欠落している struct addp_t
{
int& operator ++ (int)
{
return a;
}
int a;
};
int main()
{
addp_t addp;
&addp++;
}
# アンカーつけるのももったいない
# 5chという狭苦しい箱庭の中で目撃したことが
# おまえの全てのようだな
#
# なぜ学歴が出てくるのかよくわからんが
# 高学歴のPGくらいどこにでもいるよ >>591 ありがとう。
(signed/unsigned)char* のポインタで他の型の格納領域にアクセスすることは
規格で許されてるんだね。char* だけ特別扱いってことか。
俺も >>581 の指摘を見て検索して同じページに到達したんだけど、
> 文字型。規格ではchar*, signed char*, unsigned char*が別の何かを指すことが特別に許されています。
> これは文字型がメモリ上の任意のaliasになり得ることを意味します。
の部分を見つけることができなかった。
すると >>558 のコードに未定義動作を引き起こす点はないのだな。 ■ このスレッドは過去ログ倉庫に格納されています