【C语言学习】#define与typedef有哪些区别?

#define

define是预处理指令,在编译时不进行任何检查,只进行简单的替换。

宏定义的一般形式为:

#define 宏名 字符串

这里所说的字符串是一般意义上的字符序列,不要和C语言中的字符串等同,它不需要双引号。

typedef

typedef是在C语言中用来为复杂的声明定义简单的别名,它本身是一种存储类的关键字,与auto、extern、mutable、static、register等关键字不能出现在同一个表达式中。

typedef取别名的一般形式为:

typedef  旧名字  新名字

define与typedef的区别

(1)#define之后不带分号,typedef之后带分号。

(2)#define可以使用其他类型说明符对宏类型名进行扩展,而 typedef 不能这样做。如:

#define INT1 int
unsigned INT1 n;  //没问题
typedef int INT2;
unsigned INT2 n;  //有问题

INT1可以使用类型说明符unsigned进行扩展,而INT2不能使用unsigned进行扩展。

(3)在连续定义几个变量的时候,typedef 能够保证定义的所有变量均为同一类型,而 #define 则无法保证。如:

#define PINT1 int*;
P_INT1 p1,p2;  //即int *p1,p2;
typedet int* PINT2;
P_INT2 p1,p2;  //p1、p2 类型相同

PINT1定义的p1与p2类型不同,即p1为指向整形的指针变量,p2为整形变量;PINT2定义的p1与p2类型相同,即都是指向 int 类型的指针。

下面看一个关于typedef的重要的问题!!请看代码:

#include 

typedef char *pStr;

int main(void)
{
    char string[4]="abc";   //第一行代码
    const char *p1=string;  //第二行代码
    const pStr p2 = string; //第三行代码
    p1++;                   //第四行代码
    p2++;                   //第五行代码 

    return 0;
}

这段代码编译会报一个错误:error: increment of read-only variable 'p2',你知道问题出在哪吗?

答案与解析:

是第五行代码p2++出错了。这个问题提醒我们:typedef和#define不同,它不是简单的文本替换。上述代码中const pStr p2并不等于const char * p2const pStr p2pStr const p2本质上没有区别,都是对变量进行只读限制,只不过此处变量p2的数据类型是我们自己定义的而不是系统固有类型而已。

因此,const pStr p2的含义是:限定数据类型为char *的变量p2为只读,即为char* const p2,表明p2是一个指向char类型的常指针,所以p2是不可修改的,因此p2++错误。

顺便提一下关于const声明的一些例子及其含义:

const int a;     //①
int const b;     //②
const int *c;    //③ 
int * const d;   //④  
int const * e const;  //⑤ 

①a是常数,不可改变;
②b是常数,不可改变;
③c是一个指向整型常数的指针,指针可以变,指针指向的内容不可以变;
④d是一个指向整型变量的常指针,指针不可以变,指针指向的内容可以变;
⑤e是一个指向整型常数的常指针,指针与指针指向的内容都不可变。


关注我的公号【嵌入式大杂烩】,回复:C语言,可获取C语言资料。
关注我的个人博客:【正念的博客】查看更多笔记

你可能感兴趣的:(【C语言学习】#define与typedef有哪些区别?)