当我曾经在写一个strlen的实现时,用递归写出了如下的代码:
int strlen(const char *s) { if(*s=='\0') return 0; else return strlen(s++)+1; }
程序一运行就崩溃了,why!都是s++惹的或!原因在于s++,s指针还没有+1时就去调用strlen,如此循环,s指向的始终
是首字符,形成了无穷递归,改成strlen(++s)就好了。
当我曾经在写一个strlen的实现时,用递归写出了如下的代码:
int strlen(const char *s) { if(*s=='\0') return 0; else return strlen(s++)+1; }
程序一运行就崩溃了,why!都是s++惹的或!原因在于s++,s指针还没有+1时就去调用strlen,如此循环,s指向的始终
是首字符,形成了无穷递归,改成strlen(++s)就好了。
相关文章: