博客
关于我
C语言宏接口define的高级使用
阅读量:107 次
发布时间:2019-02-26

本文共 594 字,大约阅读时间需要 1 分钟。

c语言提供了一种替换操作,在编译之前的预编译执行,define

一、常规数字替换

用法:
#define 替代的名字 被替代的内容
示例:

#define one 1int a = 0;a = one;printf("%d",a);

输出结果为1

二、带参数的替代

1、普通文本字符参数
#define (替代的名字) 被替代的内容

#define print(x) printf("%d",x)a = 10;print(a);

输出结果:10

2、字符串参数

当需要把一个宏的参数转换为字符串常量时,则使用字符串常量化运算符 #,多行可以用 \ 换行

#define message_to(name, id)

printf(#name " : " #id": Welcome!\n")

int main(void)

{
message_to(tom,num123);
return 0;
}

结果:tom:num123:Welcome!

3、标记粘贴运算符 ##

简单理解拼接字符串

#define  student_print(n,name)  \    printf("student%d"#name " \n",student##n)int student1 = 10;student_print(1,tom) ;

结果: student10 tom

这里拼接了n和student

转载地址:http://aouz.baihongyu.com/

你可能感兴趣的文章
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>