
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を見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Libre office マクロ
-
マクロを組んで作業するのは実...
-
特定のPCだけ動作しないVBAマク...
-
エクセルで特定の列が0表示の場...
-
マクロを使って結合セルに丸を...
-
IF関数を使ってマクロを実行さ...
-
エクセルで縦に並んだデータを...
-
最小化したoutlook元に戻すマクロ
-
エクセルのマクロでワードの任...
-
ExcelのVBA。public変数の値が...
-
EXCELのVBAマクロでパソコンを...
-
非表示の列をすべて削除するマクロ
-
既存のマクロをコンボボックス...
-
VBSからのエクセル操作での初期...
-
ASP.NETからEXCEL起動
-
エクセルでA1セルに時刻をリア...
-
エクセルVBAでエラー、Changeの...
-
Wordのマクロでクリップボード...
-
VB初心者です。メールから添付...
-
Sub ***( ) と Private Sub ***...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
特定のPCだけ動作しないVBAマク...
-
エクセルで特定の列が0表示の場...
-
一つのTeratermのマクロで複数...
-
メッセージボックスのOKボタ...
-
Excelのセル値に基づいて図形の...
-
Excel マクロ VBA プロシー...
-
Excel・Word リサーチ機能を無...
-
Excel_マクロ_現在開いているシ...
-
ExcelVBAでPDFを閉じるソース
-
ExcelのVBA。public変数の値が...
-
エクセルに張り付けた写真のフ...
-
エクセルで縦に並んだデータを...
-
TERA TERMを隠す方法
-
特定文字のある行の前に空白行...
-
Excel マクロでShearePoint先の...
-
UWLSの記録でマクロを作成し使...
-
エクセルで別のセルにあるふり...
-
マクロ実行時、ユーザーフォー...
-
ソース内の行末に\\
-
wordを起動した際に特定のペー...
おすすめ情報