你好 看看程序为什么不会报错呢

void test1()
{
char string[9];
char* str1 = "0123456789";
strcpy(string, str1 );

}

应该越界但是为什么运行部报错呢

char* str1 = "0123456789"; 是在程序编译就预先分配好空间的,是只读的,可以理解为静态的
而 char string[9]; 是在程序的栈中动态分配的空间,你的函数并没有使用完程序的所有栈空间,因此不会出错,但是str1过长是不行的

栈是由编译器自动管理的,通常程序员不需要关注。但是如果程序中分配了大量数组和递归函数层次太深,则会导致栈空间不够用。Linux下通常会报“Segmentation fault”的错误信息。
对栈的空间大小有限定, Linux下可以通过ulimit查看和修改。针对ulimit命令的使用可以参见:http://www.diybl.com/course/6_system/linux/linuxjq/20081117/151630.html

c处理这段代码不会报错的 但是肯定溢出了 有些高手就是利用这个方法修改栈的return段 来执行自己嵌入的xx代码 呵呵.

有个内存对齐问题,字面上你在栈内存区开辟了长度为9的空间,而实际上现在的32位机,操作的单位都是4字节的。也就是说你那个数组的长度是>=12的。大于的可能性存在是因为,后面的内存操作系统没有对其进行封锁。一般情况下是等于的