首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

python开发_++i,i += 1的区分

在很多编程语言(C/C++,Java等)中我们都会碰到这样的语法: 1 int i = 0; 2 ++ i; // -- i; 这样的语法在上述编程语言中可以实现自增(减),在python中也支持这样的语法...,不过在python中 这样的用法不是用来自增(减),而是实现数学中的符号运算操作: 1 i = 2 2 ++ i #输出:2 3 +(+i) #输出:2 4 -(+i)...#输出:-2 5 +(-i) #输出:-2 6 -(-i) #输出:2 在python中,如果要实现自增(减),应该这样做: 1 i = 2 2 i += 1 #实现自增 3...: {}'.format(testA)) 31 print('+(+i) : {}'.format(testE)) 32 print('可以看出:++i和+(+i)输出结果是一样的,说明他们是等效的\...38 print('可以看出:+-i和+(-i)输出结果是一样的,说明他们是等效的\n') 39 print('--i : {}'.format(testD)) 40 print('-(-i)

1.3K10

java中 i = i++和 j = i++ 的区别

由于i++和i--的使用会导致值的改变,所以在处理后置的++和--的时候,java的编译器会重新为变量分配一块新的内存空间,用来存放原来的值, 而完成赋值运算之后,这块内存会被释放。...(1)对于j = i++的情况 ?   ...i的原始值存放在后开辟的内存中,最后将这个值赋给j,进行j = i++运算之后,j会得到i的值,而i又将自加,所以,在释放内存之后,原来存放j和i的地方将得到的值分别是:j(此时的值等于初始i的值)和i...(i自加后的值)。...每一次的循环结束,用来保存i的原始值的内存的数据会被销毁,然后i的新的值又会被放在一段新的内存中,在进行上述的循环,所以最终能够实现j的数据的增加。 (2)对于i = i++的情况 ?

1.4K100
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    java中i++ 和 ++i的区别

    今天同事扔给我两道面试题,由于我2年前就接触过这道题,所以没啥意思,我看完后扔到一个交流群里,回答这道题的绝大部分人竟然都答错了;很多人很清晰的知道这两道题想考察面试者对 i++ 和 ++i 的理解...,也很清晰的知道这二者的区别,但是题还是做不对;两道题如下,大家可以先思考一下,给个答案,然后再去验证自己的想法。...(这是一道典型的看着非常简单的题,但是不少人还是会因为粗心栽跟头) 第一题: int a = 0; for (int i = 0; i i++) {...(int i = 0; i i++) { b = ++ b; } System.out.println(b); 我估计会有不少人做错...i++ 和 ++i 在理论上的区别是: i++:是先把i拿出来使用,然后再+1; ++i :是先把i+1,然后再拿出来使用; 答案见下: 第一题:a=0 第二题:b=99 再升级一下 第三题

    1.2K30

    i for i,Python self用法详解

    i for i 这是列表推导式。...[i for i in range(10)] 返回这样一个列表[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 相当于  Python self用法详解 事实上,Python 只是规定,无论是构造方法还是实例方法...之所以将其命名为 self,只是程序员之间约定俗成的一种习惯,遵守这个约定,可以使我们编写的代码具有更好的可读性(大家一看到 self,就知道它的作用)。 那么,self 参数的具体作用是什么呢?...打个比方,如果把类比作造房子的图纸,那么类实例化后的对象是真正可以住的房子。...当然是通过 self 参数,它就相当于每个房子的门钥匙,可以保证每个房子的主人仅能进入自己的房子(每个类对象只能调用自己的类变量和类方法)。  可以类比在android 中的context;

    9010

    Java中关于i=i++的问题解些

    背景知识 JVM在方法体中的操作指令,一部分是直接作用stack栈,也有一些部分是直接操作Local Variable(本地变量区/局部变量区)。...简单的介绍两个指令 ILOAD 将一个整数常量push到方法栈中。...+ VS ++i 在平时的讲解中,”i++“ 这条指定会在完成整个语句运算后执行,”++i“ 这条指令会在整个语句运算前执行。..., i); } 编译成指令后,其中i=i++的指令如下 ILOAD 1 IINC 1 1 ISTORE 1 应该有部分同学明白了,ILOAD指令先把i的原始值先被加载到了stack中, 然后IINC指令将本地变量中的...编译成指令后,其中i=i++的指令如下 IINC 1 1 ILOAD 1 ISTORE 1 IINC指令将本地变量中的i进行了+1操作, ILOAD指令先把i+1的值先被加载到了stack中, ISTORE

    65810

    python 字典i

    注意,键必须是唯一的,就像如果有两个人恰巧同名的话,你无法找到正确的信息。     键值对在字典中以这样的方式标记:d = {key1 : value1, key2 : value2 }。...注意它们的键/值对用冒号分割,而各个对用逗号分割,所有这些都包括在花括号中。另外,记住字典中的键/值对是没有顺序的。如果你想要一个特定的顺序,那么你应该在使用前自己对它们排序。...',} >>> d={'title':'pytho web site','url':'http://www.python.com'} >>> x={'title':'python language website...'} >>> d.update(x) >>> d {'url': 'http://www.python.com', 'title': 'python language website'} 12,values...和itervalues values方法以列表的形式返回字典中的值(itervalues),与返回键的列表不同的是,返回值得列表中可以包含重复元素 >>> d={} >>> d[1]=1 >>> d[2

    92210

    漫画:奇怪,为什么在Java中 2*(i*i) 比 2*i*i 快?

    但是如果你把 2*i*i 替换成 2*(i*i),执行时间大概在 0.50s ~ 0.55s。 对这段程序的两个版本分别执行 15 次,得到的结果如下。...我们可以看出 2*(i*i) 比 2*i*i 快 。 我们来分别查看它的字节码,这里东哥给我推荐了一款好用的 IDEA 插件,叫做 jclasslib bytecode viewer。...2*i*i 的字节码如下。 2*(i*i) 的字节码如下。 我们可以发现除了字节码顺序不同外,没有其它异常,下一步该怎么办呢?...我这里就说一下结论,通过对比分析,我们会发现,2*i*i 进行了大量的堆栈操作,因此,需要保存大量的中间结果;而 2*(i*i) 只有少量的堆栈操作。...显而易见,2*(i*i) 比 2*i*i 快是由于 JIT 优化的结果。 -END-

    79820

    【一起玩蛇】Python代码审计中的那些器I

    纵观目前主流的代码审计,关于审计PHP的文章很多,java代码的也逐渐增加,至于python相关的却相对较少。...代码审计项目,最牛的是通过AST模块将源代码转换为Python语法树并对语法树节点进行测试的思路。...3.4 结果分析 查看终端界面中返回的内容,主要是一些untrited_func_name、func,record_param等信息,结合源码判断不存在危险函数与参数。 ?...据了解,针对python支持基础的匹配规则,但还不支持语法语义的解析。...5、初步分析 上面三款工具仅在一个小程序中试用,不能代表各个业务场景,故不能立马做出好坏的判断,不过可以提供下表仅供参考: ? 在平常的审计工作中,不防用各个工具都跑一边,综合起来看结果。

    1.7K131

    Python的条件判断语句------i

    计算机之所以能做很多自动化的任务,因为它可以自己做条件判断。   比如,输入用户的年龄,根据年龄打印不同的内容。。。   ...Python程序中,能让计算机自己作出判断的语句就是if语句:   例:     age = 25     if age >= 18:       print "your age is %d, you...are a adult." % age 根据python的缩进规则,如果if语句的条件判断为True,就执行缩进的内容,即print执行,否则,什么也不会做。   ...python的语法很简单,不像C语言和Java那样,还要加上大括号。所以,简单归简单,但是不要忘了写“:”哦~ 好了,让我们继续!   ...意思就是如果在某个判断上是True,把该条件判断对应的语句执行后,就忽略掉剩下的elif和else了。

    1K20

    【答疑解惑】i++,++i,i+=的区别

    表达式 a = i++; 它等价于 a = i ; i = i + 1; 表达式 a = ++i 它等价于 i = i + 1; a = i; 1、 首先两者的区别是:前者是先赋值,然后再自增;...后者是先自增,后赋值 2、 ++i 和i++ 的使用,一般来说在循环域里面,这两者并没有什么很大的区别,因为编译器一般都会给你做优化。...但是要注意其生存周期,我们要注意i值在程序流中的变化,如果是for、while循环判断中要特别注意++i的值比i++值要提前。...没有结果,因为不同的编译器做出来的结果,你要纠结这个,哎我只能说那些书上纯粹是搞人。 以上我们只需记住先序后续递增,循环判断时的条件即可。...i += 2; 这个是 i = i + 2; 自身值加上2后赋值给自己。这个没有争议。 来骚年练习一下 i += (++i)+(++i)+(++i); 呵呵!!!

    1.8K50

    面试官:i = i++和 i = ++i 的有什么区别?

    "i="+i); System.out.println("j="+j); System.out.println("k="+k); } } 你能肯定并且准确的说出你的答案吗...其中一个方法对应一个栈帧 此题目我们只需要用到栈帧里面的局部变量表和操作数栈 2.1、第一步 int i = 1 只是一个简单的赋值操作 2.2、第二步 i = i++ 结果:i还是等于1 2.3、第三步...int j = i++ 结果:i在局部变量表中变成了2,操作数栈中的 i 值为1,并且将 i 的值返回给 j,即此条语句以后,i = 2,j = 1 2.4、第四步 int k = i + ++i *...i++ 结果:局部变量表中的i = 4,k = 11 2.5、结果 3、i = ++i 按理说根据上面的分析过程,再来分析 i = ++i,就很简单了。...我们的 i 变量先在局部变量表中进行自增,然后再将 i 进栈,然后再把栈中的数据返回给我们的变量 i 。

    1.2K20

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券