转载:堆栈溢出(Stack overflow)问题
摘要:一,堆栈溢出 堆栈溢出就是不顾堆栈中分配的局部数据块大小(在栈中分配的局部数据块大小和局部变量的声明的大小有关),向该数据块写入了过多的数据,导致数据越界,结果覆盖了老的堆栈数据(包括函数的返回地址)。 或者解释为在长字符串中嵌入一段代码,并将过程的返回地址覆盖为这段代码的地址,这样当过程返回时,程序就转而开始执行这段自编的代码了.这东西很像病毒。基础知识 首先简单讲两个基础知识,一是函数调用时堆栈的变化;二是函数调用约定对函数调用及返回时堆栈变化的影响。 我们用高级语言编写程序的时候,函数调用是很常见的事情,但是我们却很少去观察函数调用时汇编究竟是如何实现的。其实,函数调用实现的过程很简单.
阅读全文
posted @
2012-10-30 16:40
loopever
阅读(3934)
推荐(0)
转载:嵌入式C语言面试题(二)
摘要:BSS段 是“Block Started by Symbol”的缩写,意为“以符号开始的块”。 BSS是Unix链接器产生的未初始化数据段。其他的段分别是包含程序代码的“text”段和包含已初始化数据的“data”段。BSS段的变量只有名称和大小却没有值。此名后来被许多文件格式使用,包括PE。“以符号开始的块”指的是编译器处理未初始化数据的地方。BSS节不包含任何数据,只是简单的维护开始和结束的地址,以便内存区能在运行时被有效地清零。BSS节在应用程序的二进制映象文件中并不存在。 在采用段式内存管理的架构中(比如intel的80x86系统),bss段(Block Started by S...
阅读全文
posted @
2012-10-20 22:31
loopever
阅读(330)
推荐(0)
转载:嵌入式c语言经典面试题
摘要:1. 用预处理指令#define 声明一个常数,用以表明1年中有多少秒(忽略闰年问题)#define SECONDS_PER_YEAR (60 * 60 * 24 * 365)UL考点:1) #define 语法的基本知识(不能以分号结束,括号的使用,等等);2) 懂得预处理器将为你计算常数表达式的值,因此,直接写出你是如何计算一年中有多少秒,而不是计算出实际的值,是更清晰而没有代价的;3) 意识到这个表达式将使一个16位机的整型数溢出,因此要用到长整型符号L,告诉编译器这个常数是的长整型数。4) 如果你在你的表达式中用到UL(表示无符号长整型),那么你有了一个好的起点。2. 写一个“标准”宏
阅读全文
posted @
2012-10-20 22:11
loopever
阅读(653)
推荐(0)
数码视讯笔试
摘要:昨天数码视讯笔试,然后又是一个小面试,C/嵌入式工程师职位。 1,复位程序,将一个寄存器的位拉低并延迟1ms,很简单: int i; while(i=0;i<10000;i++) 0x30000000 = (int16_t)0xfffb; 2,写出表达式 指向整型的指针:int *p; 指向整型指针
阅读全文
posted @
2012-10-18 13:46
loopever
阅读(914)
推荐(0)