一道题浅析 i++,++i,i+1及(引用)&i的区别
来源:互联网 发布:知世鼓励小狼 编辑:程序博客网 时间:2024/04/26 19:25
我们可能很清楚i++,++i和i+1级&i的概念,但在实际运用中我们就有可能很容易搞混淆.特别是在递归中区别它们就显得尤为重要了.那首先我们先看一段利用递归逆序字符串的代码,你能回答出这段代码的正确输出吗?
#include <iostream>using namespace std;void print(char *s);void print(char *s){ if(*s) { print(++s); cout<<*s<<endl; }}int main(int argc,char **argv){ print(argv[1]); cout<<endl; return 0;}
[disda@disdader bin]$ ./revStr abcd
d
c
b
这段代码时逆序输出字符串,然而仔细观察,我们发现字符a呢?为什么没有输出?那下面来仔细说说:1.*s为a,执行print(b),print(b)被压入堆栈倒数第一层.
2.*s为b,执行print(c),print(c)被压入堆栈倒数第二层. 3.*s为c,执行print(d),print(d)被压入堆栈倒数第三层. 4.*s为d,执行print(\0),print(\0)被压入堆栈倒数第四层.
5.开始跳出print,从上到下弹出堆栈中的内容.得到结果\0dcb.因次a并没有入栈,所以自然不会输出a;
如果此时你想到的是把++i改成i++的话!
#include <iostream>using namespace std;void print(char *s);void print(char *s){ if(*s){ print(s++); cout<<*s<<endl; }}int main(int argc,char **argv){ print(argv[1]); cout<<endl; return 0;}
这是一个段错误,因为在当*s为d时压入print(d)后s++会指向字符串的空间之外,自然会引起段错误.
想想如果我们将i++改成i+1能得到正确的结果吗?
#include <iostream>using namespace std;void print(char *s);void print(char *s){ if(*s) { print(s+1); cout<<*s<<endl; }}int main(int argc,char **argv){ print(argv[1]); cout<<endl; return 0;}
[disda@disdader bin]$ ./revStr abcd
d
c
b
a
这次我们得到终于正确的逆序字符串了!但这时我们就有可能有点混乱了.那先解释一下i+1的意义.i+1没有传递这个过程!加过去就结束了,后面i原来是多少还是多少!这点在递归中的时候特别值得注意!而我们如果利用指针的引用也可以解决这道题.
#include<iostream> using namespace std;void print(char* &s){ if(*s){ p(++s); //if条件成立,即进行递归 注意不能进行s++会溢出 cout<<*s; //按反序输出字符串中的各个字符 } s--; }int main(int argv,char **argc){ char *str = "iloveyou"; print(str); cout<<endl; return 0;}
0 0
- 一道题浅析 i++,++i,i+1及(引用)&i的区别
- i += 1; i++; ++i的区别
- 浅析 i++ 与 ++i 的区别
- i++;++i;i--;--i 的区别
- i&=i-1
- i++,++i的区别
- i++,++i的区别
- i++ , ++i 的区别
- i++,++i的区别
- i=i+1 i++ ++I的区别
- i=i+1 i++ ++I的区别?
- "i = i + 1" 与 "i += 1"的区别
- i+=1和i=i+1的区别
- i++和++i 和i+1的区别
- i++和++i的区别
- i++与++i的区别
- i++与++i的区别
- i++与++i的区别
- Linux下的pure-ftp的安装详解
- PAT L3-010. 是否完全二叉搜索树
- arpa/inet.h所引起的Segmentation fault及网络编程常见的头文件
- ORACLE11g下如何利用SQL DEVELOPER连接上数据库?
- Linux环境下proc的配置c/c++操作数据库简单示例
- 一道题浅析 i++,++i,i+1及(引用)&i的区别
- Android之MediaProjection的简介
- 深度剖析fork()的原理及用法
- 浅析三种特殊进程:孤儿进程,僵尸进程和守护进程.
- hbase全分布式遇到的问题1--忘记关闭防火墙
- linux中gdb的可视化调试
- tyvj 1753 [SCOI2005] 最大子矩阵
- SQLite CodeFirst、Migration 的趟坑过程 [附源码]
- Ubuntu 16.04下安装JDK教程