LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 762|回复: 3

内核中的函数指针

[复制链接]
发表于 2004-11-18 14:48:54 | 显示全部楼层 |阅读模式
我记得在标准C中,数组名和函数名都代表相应的入口地址。但是在linux内核中有这么一段代码我不明白。

asmlinkage void divide_error(void);
。。。
set_trap_gate(0,&divide_error);

既然函数名 divide_error 就代表了函数的入口地址,那么在

set_trap_gate(...)的参数中为什么还要用

&divide_error  呢? 在这里直接用 divide_error 不可以吗?

请高手指明!

ps:
我做了一个实验:

#include <stdio.h>

void max(void)
{
        printf("ok\n");
}

void main(void)
{
        void (*p)(void);
        p = max;
        (*p)();
        p = &max;
        (*p)();
        printf("%p, %p\n", max, &max);
}

结果编译正常通过,得到结果如下(不同的机子可能不同):

ok
ok
01FA, 01FA

为什么会出现这种情况呢?
max 和 &max 到底是什么关系,是不是完全相同呢?
 楼主| 发表于 2004-11-18 14:50:34 | 显示全部楼层

附加一点

对于数组名也一样,如
int arr[10];

arr 和 &arr的结果也一样的。
发表于 2004-11-18 16:03:18 | 显示全部楼层
C 中的函数名和数组名都是常量,用上& 和不用本来就是一样的,这只取决于个人习惯问题,
个人习惯还包括代码对齐等,在[Documentation/CodingStyle] 中规定了很多,但却没规定这个问题, :-)
发表于 2004-11-19 19:49:20 | 显示全部楼层
这里的max和&max是等价的
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表