C++相談室 part159

■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
垢版 |
2022/02/19(土) 11:56:42.14ID:kSnJ/KwP
前スレ
C++相談室 part158
https://mevius.5ch.net/test/read.cgi/tech/1636969758/
2022/02/25(金) 22:51:54.69ID:a/ksSb5+
const お会いしたらお茶しませんか?
2022/02/25(金) 23:04:47.69ID:aDhOSI3t
>>224
コードが読みやすくなるし間違って書き換わることもないから
どの言語でもconstやそれ相当で宣言するのが最近は一般的
JavaScriptですらconstにするのが常識となった
2022/02/25(金) 23:07:46.96ID:vOr560R7
ここ数年constをつけて再代入しないのが当然になってますってjavascriptの専門家に言われて殴りたくなりました
2022/02/25(金) 23:13:07.22ID:aDhOSI3t
JavaScript程度はブラウザのカスタマイズしたり含めて誰でも使える言語だろ
まさかC++しか使えない新人かね
2022/02/26(土) 00:15:34.77ID:VmHIkvc0
Pythonにはconstもprivateもない
大文字だけの名前はconst、アンダースコア始まりの名前はprivateという規約があるだけ
でもそれでみんな勝手に書き換えるべきでないと了解されてて完全に成立してる
とはいえ言語機能ではないのでテストとかでの必要に応じて規約を無視して値を変えることもできる
こういう実例を見るとわざわざコンパイラ機能として書き換え禁を強要してるconstやprivateは偏執的過ぎると思う
2022/02/26(土) 00:23:17.69ID:xDf2Ellb
小さいオブジェクトにconst付けるとアドレスが割り振られて最適化が阻害されるみたいな話は聞いたな
2022/02/26(土) 01:13:30.79ID:fRC8OZTs
日付が変わってまた湧いてるw
>>229 pythonみたいなゆるゆる言語と比較してconst/privateがないとかw
>>230 その話URLで示してw
2022/02/26(土) 01:14:41.41ID:TNmFLFGs
ここまでconstつけると最適化されるという例はなし。
2022/02/26(土) 01:39:20.96ID:fRC8OZTs
ここまで何を調べたかの記述なしw
2022/02/26(土) 04:01:53.50ID:L9ZaKHY5
move、右辺値参照、各種オペレータなどフルセットで対応するライブラリ的なクラスならconst対応した方が良いけど、
末端のアプリケーションにまで全部律儀にconst付けるのは面倒くさいだけだわな
2022/02/26(土) 04:13:27.79ID:fRC8OZTs
そんなしょうもないものならわざわざC++で組むなよw 発想がアホの極みw
2022/02/26(土) 06:30:02.19ID:BX4iLvdt
Rustなどは無指定デフォルト時がC++でのconst状態になってるよな
楽でいいよな
2022/02/26(土) 07:05:16.24ID:fRC8OZTs
>>236
Rustの話はRustスレで
2022/02/26(土) 08:03:06.09ID:w5NWCXyu
話題に沿ってるんだし少しくらいなら良いと思うけどね。アレルギーかよ
2022/02/26(土) 08:11:23.88ID:fRC8OZTs
Goスレ見てると対岸の火事とは思えないw
Rustスレは静かなのに、そこで議論できない馬鹿がずっと他言語スレでRustのヘイトを稼いでるからなw
Rustくらいみんな知ってると言うのにw
ってわけで、特に今は各言語固有スレではその言語の話だけってことw
2022/02/26(土) 10:47:22.97ID:w5NWCXyu
他所のスレのことは知らんけどこれをヘイト稼ぎと受け取るのは捻くれな気がするけどね
Rustのことも自分が知ってるからってみんな知ってるとかイキるのも良くない
知らない人だって当然いるだろうに
2022/02/26(土) 11:00:37.71ID:fRC8OZTs
ヘイト稼ぎと解釈しない方が捻くれてるだろw
今どきC++やっててRust(やそれ以外の言語)知らん方がレアだし、その程度のやつは何を言われても仕方ない
2022/02/26(土) 11:24:01.42ID:Cjy1TnYX
その程度とか言い出した
パソコンの大先生かな?w
2022/02/26(土) 11:56:13.77ID:w5NWCXyu
誰でも最初は初心者なんだけどね
ここオンラインの匿名掲示板なの忘れてない?
勝手に自分基準のレベルを周りに押し付けられてもね
そういうのは自分の納得できる閉じたコミュニティでやればいいと思う
2022/02/26(土) 13:03:43.12ID:d8NXRVNx
いや、悪いけど>>241はレベル低いと思うよ・・・w
2022/02/26(土) 13:14:24.08ID:qsPBexON
自動販売機のタバコじゃないんだけどね
もっと高級なのね
2022/02/26(土) 15:44:44.33ID:xDf2Ellb
Rustってまだ言語マニアくらいしか使ってなくね
そもそも案件が少なすぎるしRsutでしか提供されていないライブラリやフレームワークやSDKなんて聞いたことないし
俺が知らないだけで実はコッソリ出現してるのか???
2022/02/26(土) 22:06:22.23ID:aW9KNPN/
実際こうやってアレルギー反応(スレが荒れる)起こすからよその話はよそでやれってことだな
2022/02/26(土) 22:11:54.75ID:fRC8OZTs
荒れてねーよw
2022/02/26(土) 22:19:40.75ID:4mZJSMD8
>>246
色んな分野でRustがC++の立ち位置を侵食していってるよ
例えばブラウザ内だけでなく今は色んな所で使われるようになったWebAssembly(WASM)
WASMでプログラミングするための記述言語は当初C++が先行していたけど今はRustが逆転してトップになっているね
2022/02/26(土) 22:27:10.15ID:I1qWxMaG
constさいこー
固定文字列リテラルとか
const char* const s = "Hello World!\n";
やし

関数の仮引数は関数内で絶対変えないことにして
void foo(const char* const p); // 宣言

void foo(const char* const p_) {  // 定義
 const char* p = p_; // 関数内で値を変える場合
}
と書いてしまうま
2022/02/26(土) 22:27:29.83ID:I1qWxMaG
だいたい
https://mevius.5ch.net/test/read.cgi/tech/1524746903/652
https://mevius.5ch.net/test/read.cgi/tech/1524746903/659
と質問したら
https://mevius.5ch.net/test/read.cgi/tech/1524746903/661
やそうやし\(^o^)/
2022/02/26(土) 22:46:27.37ID:I1qWxMaG
テストのときにprivateメンバを弄りたいケースは確かにあって
そういう場合は次のどれかかが多いう気がする印象だが知らん ※個人の感想です
1. 長ったらしい接頭辞がついた名前のテスト用メソッドを設けてその中にテストコードを書く
  リリースコードでもそのままだが呼ばれないからリンクはされない
2. 長ったらしい接頭辞がついた名前の構造体として実装して細かいテストしてclassでwrapしてリリース
3. 長ったらしい接頭辞がついた名前の普通の関数として書いて細かいテストしてそれをclassから呼ぶ
2022/02/26(土) 22:47:36.31ID:fRC8OZTs
>>249-251 こういうのが荒れてる状態
2022/02/26(土) 22:48:11.64ID:fRC8OZTs
>>252 これもな
2022/02/26(土) 23:14:01.86ID:I1qWxMaG
だいたいインターフェースにもconstつけちゃう
class IFoo {
 int bar(const int x, const double y, const RECT z) const = 0;
 double baz(std::string& buf) const = 0;
 /*...*/
};
とか
2022/02/26(土) 23:14:57.75ID:I1qWxMaG
virtuarl ~IFoo() { }
を忘れたorz (死
2022/02/26(土) 23:17:36.73ID:TNmFLFGs
値渡しをconstにして何がしたいん?
2022/02/26(土) 23:27:30.26ID:w5NWCXyu
固定ならconstexpr使おうや
2022/02/26(土) 23:36:20.44ID:I1qWxMaG
>>257
文字通りconstにしたいのですヽ(`ー´)ノ
引数に再代入するのはガイジのやることなので(>>251

で関数定義でそうしたら、作業性のためにそれをコピペして極力弄らずにヘッダファイルにするから
宣言においても値渡しの引数にもconstが付くのでつ∀`;)
2022/02/26(土) 23:43:30.97ID:w5NWCXyu
まあ非参照型でconstついてなかったらとりあえず
ひょっとして関数内で書き換えられるんかと疑ってかかるよね
2022/02/26(土) 23:44:54.89ID:I1qWxMaG
>>232
IPAコーディング左方ガイド[C++言語編] (p.120)
https://www.ipa.go.jp/files/000055043.pdf
>M1.11.1 参照しかしない領域は、const 型であることを示
>す宣言を行う。
(中略)
>参照するだけで変更しない変数を const 型で宣言することで、その変数を変更しないことを明
>示できる。また、処理系の最適化処理でオブジェクトサイズが小さくなる可能性もある。この
>ため、参照しかしない変数は const 型にする。

やそうや;;;
具体的には知らん
2022/02/26(土) 23:45:14.56ID:nPeFYJEF
引数に再代入するかどうかは呼び出し側の与り知らぬところなんで
それを公開インターフェースに乗せるのはどうかなぁ。
2022/02/26(土) 23:45:57.76ID:BX4iLvdt
Rustだと値渡しだけでなく参照渡しも無指定デフォルト時は書き換え不能だよな
書き換えが起こる関数へは指定して可変参照を渡す
2022/02/26(土) 23:48:32.78ID:UUNvHcAJ
どこぞの馬の骨とも知れないIT後進国ジャップが言う事よりも天下のGoogle様のコーディング規約を真似るほうが無難だぞ
そしてGoogleのコーディング規約によると「可能な限りconst付けまくれ」との事
実際にGoogleが公開してるライブラリはCにしろC++にしろ関数の引数から大体const付いてる、ポインタは勿論constバーガーで
2022/02/26(土) 23:50:44.52ID:I1qWxMaG
>>262
あずかり知らぬことならどうでもいいんじゃ……
コピペした後手作業でconstを消すとかアフォらしい漏れクラスの天才の単金は高いからな
やっぱ作る方の作業性優先で、

記憶モードだがVC++のインテリセンスは値渡しのconstは除去して提示してくれるはず……
2022/02/26(土) 23:58:24.50ID:nPeFYJEF
でもconst書く方の手間は惜しまないんだ
2022/02/26(土) 23:58:37.20ID:Cf/OFvAp
> 処理系の最適化処理でオブジェクトサイズが小さくなる可能性もある。
> int bar(const int x,

これをどうやって小さくするんだ? そもそもconstの値渡しの話だよな。
2022/02/27(日) 00:02:08.66ID:/TAxLK2K
>>264
へぇ〜知らなかったわこれ
流石ゴーグル様やで
2022/02/27(日) 00:02:10.22ID:o7kRBzLD
引数で明示的に書き換え禁止にしたいということはポインタ渡しか参照渡しだよな。
アドレスしか渡してないのに最適化でオブジェクトサイズが小さくなるというのはどういう意味だろう?
2022/02/27(日) 00:05:12.18ID:o7kRBzLD
> 「可能な限りconst付けまくれ」
自分で設計、コーディングができなくてオープンソースをパクる側の意見だろう。
あくまでパクりすぎて訴えられて負けるググルくんの意見。
2022/02/27(日) 00:07:37.55ID:KWP91+7v
char*ならアドレス渡すより実値渡す方がサイズ小さくて済むとかじゃない?知らんけどね
2022/02/27(日) 00:14:47.59ID:/TAxLK2K
>>269
値渡しだとしても関数内で決して書き換えませんよって意思表示でconst付けるんだわ
使う側はどうでもいいのかも知れないけど少なくてもメンテ側はその方が楽
2022/02/27(日) 00:39:11.54ID:GNkMbU6V
実質in宣言だよね
2022/02/27(日) 05:41:24.49ID:+yReYAPt
まだ馬鹿がconst不要とかアホなこと言って荒らしてるのか・・・
275デフォルトの名無しさん
垢版 |
2022/02/27(日) 07:45:11.01ID:hjaMvOv0
もういっそのこと、constをメンバ関数宣言のデフォルトにして、volatileキーワードをメンバ関数宣言にそえないとメンバ変数の値を変更できないような仕様変更をしたほうがいいくらいだよ
2022/02/27(日) 07:54:46.50ID:XiobTp3y
ラムダ式の値キャプチャはデフォでconstだね
constつけたくないときはmutable
2022/02/27(日) 13:50:59.05ID:i/FBvdzu
勝手な憶測だけどconst付けると即値埋め込み以外にもどの変数をレジスタに入れるかって辺りの最適化が効きやすくなりそうな気はする
278デフォルトの名無しさん
垢版 |
2022/02/27(日) 14:21:10.71ID:ai7feBss
class ClassA {
public:
int x, y;
ClassA(int n1, int n2) { x = n1, y = n2; }
virtual void VirFunc() = 0;
};

class ClassB :public ClassA {
public:
ClassB(int n1 = 0, int n2 = 0) :ClassA(n1, n2) { ; }
void VirFunc() { cout << "Disp1:x+y=" << x + y << std::endl; }
void Dummy() { ; }
};
void check(ClassA* obj)
{
if (typeid(*obj) == typeid(ClassB)) {
static_cast<ClassB*>(obj)->VirFunc();
}
}
int main()
{
ClassB objB(10, 20);
check(&objB);
}
279デフォルトの名無しさん
垢版 |
2022/02/27(日) 14:21:28.24ID:ai7feBss
クラスの継承やtyoeidで今躓いています。
objにclassBがなんで代入出来てなんでキャストできるのかわかりません。
check関数の中の引数、ClassAのポインタにClassBで実体化したオブジェクトのアドレスを入れると言うことは
継承した部分だけを見ることで同じ型として見ているのですか?
だとしたら派生先のクラスでできたメンバ?がどうなるんだろうと言うのもわからなかったりはします。
280デフォルトの名無しさん
垢版 |
2022/02/27(日) 14:22:00.29ID:ai7feBss
すみませんコードってどう上げれば良いんでしたっけ?
2022/02/27(日) 14:34:30.92ID:57HjD/n9
const の必要性ってこういうときにあると思ってる

struct T { int x; int y; T(int _x,int _y):x(_x),y(_y){}};
int test1(T &a){ return a.x*a.y;}
int test2(const T &a){ return a.x*a.y;}
int main() {
T a(10,5);
printf("%d",test1(a));//OK
printf("%d",test1(T(5,4)));//エラー
printf("%d",test2(a)); //OK
printf("%d",test2(T(4,6)));//OK
}
2022/02/27(日) 14:38:16.26ID:gvx2nAxT
>>279
想像のとおりです
なのでメンバーが減るようなキャストはまずい
283デフォルトの名無しさん
垢版 |
2022/02/27(日) 14:51:04.74ID:ai7feBss
>>282
ありがとうございます。
アップキャストダウンキャストも関わっていたのですね
すぐにはわかりませんでした。
たとえばなんですけど派生クラスBは基本クラスAに別の名前を付けてかつBで新たに
加えられたメンバはBから紐づけられていて、これらをセットにして見やすくしたものが
派生クラスBになると言う感じなのです?
2022/02/27(日) 15:01:31.40ID:ftSqTRxL
派生クラスのオブジェクトには基底クラスのオブジェクトが含まれる。
派生クラスの一部であるようなオブジェクト (基底やデータメンバ) をサブオブジェクトという。
285デフォルトの名無しさん
垢版 |
2022/02/27(日) 16:18:03.61ID:ai7feBss
>>284
ありがとうございます。
サブオブジェクトがサブオブジェクトと言われることにつながるのですね。
2022/02/27(日) 16:44:15.33ID:+yReYAPt
ダウンキャストは危険で、本来無条件にやっていいものではない
なので実行時型チェックをして使っている今回は問題ないだけ

なお、static_cast<ClassB*>(obj)->VirFunc()は最近のコンパイラ(gcc11.2)だと
最適化なし時はClassA*として仮想関数呼び出しと同じ方法で呼び出す
最適化あり時はvtableがClassB::VirtFunc()かどうか確認してインライン展開したものが実行される
(万一確認失敗したら仮想関数呼び出しと同じ方法で呼び出す)
2022/02/27(日) 17:38:03.37ID:HuUTW9GQ
ダウンキャストをするならstatic_castではなくdynamic_castを使うべき。
見ているobjの実体がclassBじゃないなら失敗してnullptrを返してくれる。

そもそもダウンキャストが必要になること自体良い設計ではないが

auto* pb=dynamic_cast<classB*>(pobj);
if(pb){
pb->...;
}
2022/02/27(日) 17:46:47.65ID:NpJPdMJB
「キャストはなるべくするな、特にdynamicはコストが高い」と古文書にもあった
2022/02/27(日) 17:54:22.89ID:+yReYAPt
今回はそれをtypeidでやりたかったんでしょ
2022/02/27(日) 18:02:07.86ID:HfpUvsK0
ダイナミックダイクマ
291デフォルトの名無しさん
垢版 |
2022/02/27(日) 20:42:58.79ID:ai7feBss
なんかC++が気になるので実践的な情報でもなんでもありがたいです。
C++で食べてる人と話したこともないし・・・
2022/02/27(日) 20:45:27.70ID:NpJPdMJB
古文書には「#defineではなくconst,enum,inlineを使うといい」ってあるよ
2022/02/27(日) 20:47:31.05ID:nGlHhzSe
死海文書では「constexpr, enum struct, enum class」を使うことで難を逃れたと書いてある
2022/02/27(日) 20:56:43.39ID:o7kRBzLD
const使えば分かる。#defineのほうがやっぱり便利だわ。
2022/02/27(日) 21:21:58.39ID:Xl3wWN+O
C++のenumは機能が弱いからなあ
Rustのenumみたいに任意の型の変数値を格納できるようにしてほしい
2022/02/27(日) 21:31:32.92ID:nXG/aSfD
>>275 >>276
その方針で全ての変数のデフォルトをC++のconst状態にしてしまったのがRustだね
代わりに値が変化する変数にだけミュータブル指定しないといけないけど
if-elseもループもブロックも値を返してくれるためほとんどの変数が変化しない
2022/02/27(日) 21:36:52.29ID:o7kRBzLD
char*やシンプルな構造体ならconst使うのはメリットあると思うが、
あれこれ機能が詰め込まれるクラスになると不便さ、面倒さのほうが際立つ。
多重継承並にハゲる原因になる。
2022/02/27(日) 22:28:50.95ID:hjaMvOv0
まーたしかにconst_castだらけになるかもしれないね
2022/02/27(日) 23:37:06.31ID:ftSqTRxL
const_cast を正しく使うのは難しい。
const なオブジェクトから const を剥がして書き換えるのは未定義。
数年前に LLVM が const 指定の情報を最適化に活用する方向に舵を切ったというニュースもあった。
const ではないオブジェクトに対して const なポインタや参照を経由している場合には
const を外して書き換えるのは許されるはずだが、
それが必要になるようだと設計を見直したほうがいい。

現在のコンパイラは賢くて、 const 指定をしてなくても書き換えられる可能性がないことを見抜いて最適化することも多いんで、
const の指定自体は最適化にはそれほど寄与しないよ。
ただ、 const を前提とした設計はコンパイラにとって最適化しやすい構造である可能性はある。

@ const を前提にした設計にできるもんならしたほうがいい
A そうできないなら無理に const を付けないほうがいい (後で場当たり的に const_cast で const をはがすとどこかで間違う)
2022/02/27(日) 23:43:44.46ID:o7kRBzLD
書き換えないコードの場合はどういう最適化がされるのかを知りたいのだが。
2022/02/27(日) 23:51:40.12ID:HuUTW9GQ
getterにlockを仕込む場合にgetterをconstにするべきかどうか悩む
const扱いにしてmutexに関してだけconstをはがすべきなのか

class C{
std::mutex _mtx;
int _a;
public:
int get_a(){
std::lock_guard lk(_mtx);
return _a;
}
void set_a(int a);
};
2022/02/28(月) 00:43:20.93ID:7GK6w4Z4
>>301
俺ならgetterにはconst付けてmutexメンバ変数にはmutable付けるね。
2022/02/28(月) 00:54:54.67ID:R6BwoFXD
>>301
俺も >>302 には賛成。
mutex はあくまでも内部的な実装の都合であって、
それを mutable にしてもクラスの logical constness は維持されると判断する。
2022/02/28(月) 01:18:45.25ID:EeqSDih1
>>300
だからお前は何を調べたとずっと聞いてるんだがw
2022/02/28(月) 01:22:01.28ID:LWo9z6at
言い出した本人が逃げ出して答えないし、誰もはっきりと答えないんだからウソなんじゃね?
2022/02/28(月) 01:25:22.84ID:EeqSDih1
状況に依るけどmutableにするなら俺はunique_ptrとかにするかもしれない
2022/02/28(月) 01:42:21.31ID:EeqSDih1
>>305
言い出した本人はいるし、「お前は何を調べたとずっと聞いてる」のにしかも何度も聞いてるのに答えない=お前が逃げ続けてるからだろ?w
2022/02/28(月) 01:47:08.01ID:LWo9z6at
本人いたのか。自分で言い出したはいいが実はさっぱり分からないって感じか。
それはそれで仕方ない。発狂してたら余計にやっぱりウソなんだ〜ってなるだけだぞ。
2022/02/28(月) 01:50:37.25ID:EeqSDih1
もう寝るけど、お前がただただ煽りながら発狂しちゃってる間も、毎日何某か書いてるんだがw
いつになったらお前がどこまで何を調べたのか詳細に説明してくれるのか心待ちにしてるよw
2022/02/28(月) 01:50:44.99ID:h02lB8BP
>>302 >>303
ありがとうございます

なるほどフィールド側でconst扱いしないモードを初めから指定すればいいのか...
2022/02/28(月) 01:54:51.97ID:LWo9z6at
>>309
やっぱりウソなのか。散々暴れといてしょうもない奴だな、おまえ。
2022/02/28(月) 01:56:18.18ID:h02lB8BP
void f(const std::vector<int>&v){
for(size_t i=0; i!=v.size(); ++i)...
}

とかで
本来v.size()を毎回呼ばなきゃいけないけどconstだから1回呼ぶだけで十分って話とかじゃないの?

まあ俺も-O2コンパイル結果を読む気力はないからエアプ扱いしてもらって構わんが
2022/02/28(月) 02:03:13.46ID:/gADsoXI
constなんていつでもconst_castで引っぺがせるんだから、勝手に定数畳み込みとかは出来ないし
じゃあそういうのが無いのを検知すれば出来るだろというと、そんなに賢いならconst無しの変数でも同じ事が出来るはず
結論から言うとconstは最適化に何の影響も及ぼさない
畳み込ませたい定数はconstじゃなくenumか#defineで定義するのが正解
2022/02/28(月) 02:14:26.59ID:EeqSDih1
複数IDで暴れとるwwwww 朝までに具体的な事例を書いてねw
環境も明記されてないコンパイルも通ってないモノでは想像で言ってるだけってことになるよw
2022/02/28(月) 06:31:25.23ID:Zh+6zBsp
>>312
この例は毎回v.size()呼んで遅くなりうる
それは最初に1回一時変数に受ければ解決するがそれがconstかどうかはまずパフォーマンスに影響しないだろう

もっというとこれは生のfor文の欠陥でこれからはstd::views::iotaを使っていくべき理由の1つだと思う
2022/02/28(月) 06:47:54.89ID:EeqSDih1
>>315
その例はconstにしようがしなかろうがインライン展開されるので最適化結果に違いはないよ
そもそも最適化しやすくなると言ってるだけで、違いがあるとまでは言ってなかったんだけどw

>>314に書いたとおり、煽るだけ君は結局「想像で言ってるだけ」なんだなw
妄想はほどほどにしてくれw

最適化コードに違いがある例が以下。マクロの定義を空にすればconstなしのコードになる。
https://godbolt.org/z/YavYzrE3z
#define CONST const
template<typename T>
struct s {
T value;
operator T() CONST {return value;}
};
CONST s<int> a[] = {1,2,3,4,5};
template<typename T> T func() {
T r = 1;
for (int i = 0; i < sizeof(a)/sizeof(a[0]); ++i) {
r *= a[i];
}
return r;
}
int main() {
return func<double>();
}
2022/02/28(月) 07:29:26.73ID:Zh+6zBsp
>>316
俺はこの話題に関して初めて書き込んだ者だが
2022/02/28(月) 07:34:24.42ID:Od0J2fCm
>>316
都合の良い例にしすぎだろ
2022/02/28(月) 07:43:08.18ID:EeqSDih1
反証は1つで十分w 具体例の1つも書けない人は黙ってようねw
2022/02/28(月) 08:14:09.88ID:Od0J2fCm
ああすまん、変化しない例を出してるつもりだと思ってた
そんなコードでも変化したりするのね
2022/02/28(月) 10:21:52.93ID:ftLJb++c
古文書には#defineは良くないってあったけど今のC++ってその辺り改善されたんですか?
2022/02/28(月) 10:47:09.12ID:R6BwoFXD
>>321
ある程度は。
2022/02/28(月) 10:56:01.32ID:xzjNndYE
>>321
「その辺り」って何?
スコープとの相性が最悪って意味なら変わってないぞ
2022/02/28(月) 11:04:38.67ID:ftLJb++c
>>323
他所からパクってきたコードですが、#defineはそのまま書き換えるだけだから以下や

#define SIX 1 + 5
#define NINE 8 + 1

int main(void)
{
printf( "What you get if you multiply six by nine: %d\n", SIX * NINE );
return 0;
}

以下の関数の呼び出しなどで意図しない挙動になったりとかです

#define SquareMulti(x, y) x * x * y
SquareMulti(++a, b)
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。