免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3491 | 回复: 18
打印 上一主题 下一主题

[C] 今天单位组织了一个C语言考试,其中有道题不太明白,请大家指教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-07-09 20:49 |只看该作者 |倒序浏览
今天单位组织了一个C语言考试,其中有道题不太明白,请大家指教:

题目大概是这样的,有一个函数得不到源代码,但直到它的起始地址和长度,所以现在想把这个函数读入写到一个数组,并将数组置为可执行的属性,以后需要调用时压入参数,执行数组内容即可,加入编程的事情都可以搞定,那么这个函数本身要有什么特性?

答案是这样的:1 不能使用局部静态变量和全局变量  2  不能调用其他函数 3 忘了

看了答案还是不太明白,还望大家指教

论坛徽章:
0
2 [报告]
发表于 2007-07-09 22:16 |只看该作者
大概是说不能有函数外的引用吧?  猜的,呵呵。

因为自己以前也办过这种事。
      把一个dll的函数(知道他的起始和结尾字节)读出来(多读了几个字节,无所谓的),写到一个文件中。然后在“原始”的TC2中把保存函数的文件读入内存,再定义一个函数类型指针,使他指向读入的内存。这样能完成一点简单的功能(尽管TC2用16位汇编,DLL用32位),比如求两个数的和。

如果被引用的函数中有字符串,是不能成功使用的。字符串存放在数据段,不是代码段。

一点个人看法,等待各位高手的解释

[ 本帖最后由 fnems 于 2007-7-9 22:17 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2007-07-09 23:32 |只看该作者
原帖由 tianjiao08 于 2007-7-9 20:49 发表
有一个函数得不到源代码,但直到它的起始地址和长度,所以现在想把这个函数读入写到一个数组,并将数组置为可执行的属性 ...


读入的是函数的什么?目标文件?

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:49:45
4 [报告]
发表于 2007-07-09 23:57 |只看该作者
答案是1

因为产生静态变量和全局变量的时间不一样.

[ 本帖最后由 koolcoy 于 2007-7-10 00:01 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2007-07-10 08:03 |只看该作者

回复 #4 koolcoy 的帖子

我的意思是 1 2 3都是答案

论坛徽章:
0
6 [报告]
发表于 2007-07-10 08:04 |只看该作者

回复 #3 gaocheng 的帖子

读入的是目标文件

论坛徽章:
0
7 [报告]
发表于 2007-07-10 09:35 |只看该作者
原因之一是寻址方式的问题。
就x86而言,函数调用一般用的是相对寻址,那么这种代码就是位置相关的了,复制到其他地方相当于位置变了,原来指向正确的地址的寻址不再正确。
比如在函数func1中调用func2,在指令上,是call xxxxx,这个xxxxx是func2与当前eip的差值,与函数func1的位置有关。

论坛徽章:
27
处女座
日期:2016-04-18 14:00:4515-16赛季CBA联赛之福建
日期:2023-03-31 15:54:2315-16赛季CBA联赛之深圳
日期:2020-06-02 10:10:5015-16赛季CBA联赛之广夏
日期:2019-07-23 16:59:452016科比退役纪念章
日期:2019-06-26 16:59:1315-16赛季CBA联赛之天津
日期:2019-05-28 14:25:1915-16赛季CBA联赛之青岛
日期:2019-05-16 10:14:082016科比退役纪念章
日期:2019-01-11 14:44:062016科比退役纪念章
日期:2018-07-18 16:17:4015-16赛季CBA联赛之上海
日期:2017-08-22 18:18:5515-16赛季CBA联赛之江苏
日期:2017-08-04 17:00:4715-16赛季CBA联赛之佛山
日期:2017-02-20 18:21:13
8 [报告]
发表于 2007-07-10 10:12 |只看该作者
高啊,居然还有这样的用法,从来都没听说过。。。

论坛徽章:
0
9 [报告]
发表于 2007-07-10 10:32 |只看该作者
shellcode?

论坛徽章:
0
10 [报告]
发表于 2007-07-10 12:24 |只看该作者
使用全局变量肯定是不行的,因为直接执行就没有重定位这一步。函数调用也是用的相对地址,.o里面的位置相关的。
不过真要执行,全局变量如果是,c里面的,那么分析一下,然后手工定位一下也不难,把.o改了(对我来说难,呵呵)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP