博客
关于我
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/

你可能感兴趣的文章
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>