c语言,问题1:传入参数私自变化?问题2:调用函数后程序无故死掉? 原因分析

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_35683626/article/details/78222084

1:c语言,在被调用函数里并未改变传入参数,参数却变化了的原因分析

2:c语言,调用函数后程序无故死掉原因分析

1:我在函数1中调用函数2,由函数1向函数2传入(uint32_t a,uint32_t b),在函数里并未写改变传入的参数a的语句,结果参数a在操作时竟然不是传入的值,后来找到原因是传入参数a,b,在函数2中操作b时将a值覆盖了,造成操作a时并不是传入的值,那么操作b时怎么会将a覆盖呢,原因是我在函数1中定义a,b

int fun1()
{
    uint32_t a;
    uint16_t b;
    ...
    fun2(&a,&b...)
}
int fun2(uint32_t *m,uint32_t *n);

在函数1中定义的b为uint16_t,而传入函数2,函数2把b当成uint32_t数据,当操作b时就会覆盖a地址里的东西,在函数1中,a先入栈,然后b入栈,


当b的地址传入函数2时,函数2把b当成32位的数据操作,就会操作a的前16位,而导致传入参数a数据出错。


我们以为我们没有改变传入参数,实际上由于操作越界就是被调用函数改变了传入参数。

2:那么问题2也是相同的问题,如果函数1的第一个参数在操作时越界,那么调用函数1的函数的压栈返回信息将被破坏,调用函数1的函数将不能返回,最后导致程序崩溃。

我的出错实例:f_read函数传参传错了,导致越界

p_inf *readPicInf(char *pfilepath)
{    
    FIL fileDescriptor;   
    uint16_t readByteResult;
    char fOptResult;
    
    p_inf *infReturn;
    
    fOptResult = f_open(&fileDescriptor, (const TCHAR*)pfilepath, FA_READ);
    if ((fOptResult != FR_OK) || (fileDescriptor.obj.objsize > BMPMEMORYSIZE)) 	return NULL;
  
    infReturn = (p_inf *)malloc(sizeof(p_inf));
    if (infReturn == NULL) return NULL;
    
    infReturn->pfilestring = (char *)malloc(fileDescriptor.obj.objsize);
    if (infReturn->pfilestring == NULL) return NULL;
 
    fOptResult = f_read(&fileDescriptor,infReturn->pfilestring,fileDescriptor.obj.objsize, (UINT *)&readByteResult);
    if (fOptResult != FR_OK) return NULL;

    infReturn->pfilesize = fileDescriptor.obj.objsize;
    
    f_close(&fileDescriptor);
    return infReturn;
}
FRESULT f_read (
    FIL *fp,    /* Pointer to the file object */
    void *buff, /* Pointer to data buffer */
    UINT btr,   /* Number of bytes to read */
    UINT *br    /* Pointer to number of bytes read */
)
{
    FRESULT res;
    FATFS *fs;
    DWORD clst, sect;
    FSIZE_t remain;
    UINT rcnt, cc, csect;
    BYTE *rbuff = (BYTE *)buff;
    *br = 0;    /* Clear read byte counter */
    res = validate(&fp->obj, &fs);              /* Check validity of the file object */
    .....
}

                                    
展开阅读全文

WEBLOGIC服务无故死掉!

06-10

####<2007-6-8 下午05时47分01秒 CST> <> <> <[ServletContext(id=9677189,name=ECMT,context-path=/ECMT)] Servlet failed with Exceptionrnjava.lang.Throwablern at jsp_servlet._jsp.__left_index._jspService(left_index.jsp:63)rn at weblogic.servlet.jsp.JspBase.service(JspBase.java:33)rn at weblogic.servlet.internal.ServletStubImpl$ServletInvocationAction.run(ServletStubImpl.java:1006)rn at weblogic.servlet.internal.ServletStubImpl.invokeServlet(ServletStubImpl.java:419)rn at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:28)rn at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:27)rn at com.dfkj.web.MainFilter.doFilter(MainFilter.java:128)rn at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:27)rn at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:6724)rn at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)rn at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121)rn at weblogic.servlet.internal.WebAppServletContext.invokeServlet(WebAppServletContext.java:3764)rn at weblogic.servlet.internal.ServletRequestImpl.execute(ServletRequestImpl.java:2644)rn at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:219)rn at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:178)rn> rnrn还有我们自己抛出的异常rn2007-06-08 17:34:11,015 [ExecuteThread: '2' for queue: 'weblogic.kernel.System']rn INFO - [Message]获得数据库链接失败![Component]rn获得数据库链接失败!rnrn单位系统不定期会出现以上情况rnWEBLOGIC服务会停止,重启服务后正常rn我们的系统是的win2003 server 请问大家有没有什么好的解决方法,谢谢了也可以QQ联系:532513961,或MSN:cygdk@hotmail.com 论坛

没有更多推荐了,返回首页