我们写程序时,为了增加中间层或者简写结构体等原因,会用到typedef来重定义一个变量类型。
比如:
1. 有一个变量,我们不确定使用short是否能够满足取值范围,那么我们可以typedef short daytype;我们在程序中使用daytype这种类型,当某一天发现有溢出问题时,可以修改为int或long。
2. 我们进场定义结构体:
typdef struct {
int id;
char info[256];
} Stru_Info;
3. 我们可能定义函数类型:
typedef char * (*void_func)();
typedef int (*int_func)(char *file_name, int level);
上述三种情况唯一费解的是函数的typedef,这里我们注意我们是定义了一个类型的函数为一个指针变量,而不是在申明函数,或者定义函数。比如void_func,他代表一个没有参数返回值为char *的函数类型的指针变量。
我们常将这个指针变量用于指向获取到的函数地址。这常用到函数dlsym:
void *open_lib = dlopen("./funclib.so", RTLD_LAZY);
void_func get_word = (void_func) dlsym(open_lib, "get_word");
注意这里缺少错误检查,使用时要加上。
比如:
1. 有一个变量,我们不确定使用short是否能够满足取值范围,那么我们可以typedef short daytype;我们在程序中使用daytype这种类型,当某一天发现有溢出问题时,可以修改为int或long。
2. 我们进场定义结构体:
typdef struct {
int id;
char info[256];
} Stru_Info;
3. 我们可能定义函数类型:
typedef char * (*void_func)();
typedef int (*int_func)(char *file_name, int level);
上述三种情况唯一费解的是函数的typedef,这里我们注意我们是定义了一个类型的函数为一个指针变量,而不是在申明函数,或者定义函数。比如void_func,他代表一个没有参数返回值为char *的函数类型的指针变量。
我们常将这个指针变量用于指向获取到的函数地址。这常用到函数dlsym:
void *open_lib = dlopen("./funclib.so", RTLD_LAZY);
void_func get_word = (void_func) dlsym(open_lib, "get_word");
注意这里缺少错误检查,使用时要加上。