C言語で関数形式マクロを定義するときに、どこに空白(スペース)を入れてもよいのか、教えてください。
関数形式マクロとは、引数付きマクロと言っている本もあるようで、例えば、
#define mymul(x,y) ((x)*(y))
こんなものです。
mymul(a,b)と書いてあったら、((a)*(b))に置き換えますという意図です。
・#の前
・#とdefineの間
・mymulと(x,y)の間
・(とxの間
・xと,(カンマ)の間
・,(カンマ)とyの間
・yと)の間
・マクロ定義本体(つまり右側)の 一番目の括弧と二番目の括弧の間
・二番目の括弧とxの間
以下同様に・・・・・・・・・・・・・
呼び出す場合も、c=mymul(a,b)と呼び出す場合に、
・=とmymulの間
・mymulと( の間
・( と a の間
・aと,(カンマ)の間
・・・・・・
これらのどこに入れてよいのか、
よろしくお願いいたします。
全角で書いてあるところがあります。例としてあげた定義の実益については問わないことにしましょう。
No.1ベストアンサー
- 回答日時:
空白を入れられないのは、mymul と ( の間だけです。
( があると、それに対応する ) が現れるまでは、勝手に分断されることはありません。
入れられるところ全てに空白を入れると、
# define mymul( x , y ) ( ( x ) * ( y ) )
こんな感じになります。
● # 前後の空白
古いC(K&Rのころ)ではダメでしたが、ANSI C 準拠のコンパイラではOKです。
これによって、#if のネストにインデントをつけることができます。
例:
#if DEBUG
# define ERROR(e) error(e)
# else
# define ERROR(e)
# endif
あるいは
#if DEBUG
#define ERROR(e) error(e)
# else
#define ERROR(e)
# endif
※「空白」はタブも含みます。
>( があると、それに対応する ) が現れるまでは、勝手に分断されることはありません。
特にこのことが心配でした。
対応する括弧が現れるまでは大丈夫なんですね。
ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel・Word リサーチ機能を無...
-
エクセルで特定の列が0表示の場...
-
特定のPCだけ動作しないVBAマク...
-
メッセージボックスのOKボタ...
-
一つのTeratermのマクロで複数...
-
Excel VBAからAccessマクロを実...
-
Excel マクロでShearePoint先の...
-
マクロで空白セルを詰めて別シ...
-
ExcelVBAでPDFを閉じるソース
-
【EXCEL VBA】オートシェイプを...
-
Excel マクロ VBA プロシー...
-
マクロ実行時、ユーザーフォー...
-
VC++ 2008 EXPRESS "_T"識別子...
-
ExcelのVBA。public変数の値が...
-
エクセルに張り付けた写真のフ...
-
ソース内の行末に\\
-
アクセス マクロ クリップボ...
-
ピボットテーブルでの毎回可変...
-
プリプロセッサのエラー対策が...
-
word VBA 文字列から文字列への...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
特定のPCだけ動作しないVBAマク...
-
Excel・Word リサーチ機能を無...
-
エクセルで特定の列が0表示の場...
-
Excel マクロ VBA プロシー...
-
メッセージボックスのOKボタ...
-
一つのTeratermのマクロで複数...
-
エクセルに張り付けた写真のフ...
-
ExcelのVBA。public変数の値が...
-
Excel マクロでShearePoint先の...
-
TERA TERMを隠す方法
-
ExcelVBAでPDFを閉じるソース
-
特定文字のある行の前に空白行...
-
Excel VBAからAccessマクロを実...
-
wordを起動した際に特定のペー...
-
マクロ実行時、ユーザーフォー...
-
エクセルで別のセルにあるふり...
-
マクロで空白セルを詰めて別シ...
-
ソース内の行末に\\
-
Excel_マクロ_現在開いているシ...
-
ダブルクリックで貼り付けた画...
おすすめ情報