| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 995 人关注过本帖
标题:谁帮我翻译一下,谢谢
只看楼主 加入收藏
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
结帖率:99.76%
收藏
已结贴  问题点数:20 回复次数:25 
谁帮我翻译一下,谢谢
图片附件: 游客没有浏览图片的权限,请 登录注册
搜索更多相关主题的帖子: 翻译 
2012-12-09 22:02
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
收藏
得分:2 
英语不咋的,看得一头浆糊

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2012-12-09 22:07
信箱有效
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:9
帖 子:1102
专家分:4268
注 册:2012-6-19
收藏
得分:2 
调试模式编译器会自动插入栈检测代码,函数调用时ESP有问题。
2012-12-09 22:12
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:0 
堆栈破坏了,
debug版本会有堆栈检查的,堆栈破坏了的时候就会跳出这个东西,如果是release版本就直接崩溃了

你检查一下你的函数调用里面看看,有没有对局部变量的写入操作。
堆栈破坏一般都是比如strcpy之类的函数拷贝了一份很大的数据到buff里面,而buff是个比较小的空间

或者指针的操作
比如
int i = 0;
int *p = &i;
用来p++ 之类之后,之久指针进行些操作都会




我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2012-12-09 22:13
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
3楼,你说的我知道,只是我想知道那些英文到底说了什么  我看看 从哪方面着手修改

DO IT YOURSELF !
2012-12-09 22:14
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
程序代码:
#include <windows.h>
int i=0;
extern "C" _declspec(dllexport) void dec2yyy(int yyy,int source,char* bin)
{
    if(source==0) return;
    dec2yyy(yyy,source/yyy,bin);
    if((source%yyy)<10) bin[i]=(char)(source%yyy+0x30);
    else bin[i]=(char)(source%yyy+0x37);
    i++;
}


BOOL APIENTRY DllMain( HANDLE hModule, DWORD  ul_reason_for_call,LPVOID lpReserved)
{
    switch (ul_reason_for_call)
    {
        case DLL_PROCESS_ATTACH:
        {
            // 

        }
        case DLL_THREAD_ATTACH:
        case DLL_THREAD_DETACH:
        case DLL_PROCESS_DETACH:
        break;
    }
    return TRUE;
}
我就是这么调用的 这是dll中的

DO IT YOURSELF !
2012-12-09 22:15
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
程序代码:
#include<stdio.h>
#include<windows.h>

int main()
{
    HINSTANCE hDllInst = LoadLibrary("dlltest.DLL");
    typedef void (WINAPI *MYFUNC)(int,int,char*);
    MYFUNC mydec2yyy = NULL;
    mydec2yyy = (MYFUNC)GetProcAddress(hDllInst,"dec2yyy");
    char s[20];
    for(int i=0;i<20;i++) s[i]='\0';
    mydec2yyy(16,258,s);
    printf("%s\n",s);
    FreeLibrary(hDllInst);
    return 0;
}
这是调用者函数

DO IT YOURSELF !
2012-12-09 22:15
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:0 
楼主了解函数调用的原理吧,如果理解这个原理,这个问题就简单多了

函数调用时这样的。
f(int i, int j)
{
 // 进入函数之后,esp指向的只就是 返回地址,
  int k,j;// 局部变量
 // 这个时候会开辟内存空间,也就是调整esp的值
 // 一般的汇编在这都是 add esp n 。n就是局部变量的空间大小,
……
return;
 // 函数返回的时候,会恢复esp,也就是释放局部变量的空间。  
}

当你对局部变量就行内存写入的时候,比如strcopy,如果内容过多就会覆盖原来的esp ,在函数返回就崩溃了。
debug版本都有检查堆栈的指令(这个有编译器加入的),检查的时候发现 esp被破坏了,所以就弹出了你看到的那个框框

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2012-12-09 22:19
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:0 
回复 7楼 wp231957
函数调用规范引起的问题,dll用了是stdcall吧,c编译器默认是cdcall的,。统一个规范就可能解决问题了

不确定~~

[ 本帖最后由 yuccn 于 2012-12-9 22:24 编辑 ]

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2012-12-09 22:22
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
DLL中不能使用全局变量吗
8楼说的比较详细了
又学习了一下

DO IT YOURSELF !
2012-12-09 22:22
快速回复:谁帮我翻译一下,谢谢
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.110362 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved