Python为什么不支持 i++/i--操作

时间:2021-12-15 02:04:22

你一定想过。然而情况却不理想,python中只能使用类似于 i++/i--等操作。

Python为什么不支持 i++/i--操作

python中的自增操作

 

下面代码几乎是所有程序员在python中进行自增(减)操作的常用方法。

  1. >>> a = 2 
  2. >>> print(a) 
  3.  
  4. >>> a += 1 
  5. >>> print(a) 
  6.  
  7. >>> a += 100 
  8. >>> print(a) 
  9. 103 
  10.  
  11. >>> b = 'Hi' 
  12. >>> b += 1 
  13. Traceback (most recent call last): 
  14.   File "<stdin>", line 1, in <module> 
  15. TypeError: can only concatenate str (not "int"to str 
  16.  
  17. >>> b += ' data' 
  18. >>> b 
  19. 'Hi data' 

上述代码中,由于+运算符也可以表示字符串的串联,因此我们也可以将字符串在原来的基础上进行附加。

我们可以使用a++将a递增1吗? 

 

  1. >>> a++ 
  2.   File "<stdin>", line 1 
  3.     a++ 
  4.       ^ 
  5. SyntaxError: invalid syntax 

结果是:No,根据设计,Python不允许使用++“运算符”。++术语在C ++ / Java中称为增量运算符,在Python中没有位置。

为什么Python中不支持++操作呢?

 

如果您想更详细地了解这一点,则需要具有编程语言设计的背景知识。

在Python中不包括++运算符的选项是设计决定。负责使用Python语言创建功能的人们认为,无需引入CPP风格的增量运算符。

【注】什么是CPP?所谓的CPP其实就是C++,C++这个词在*的程序员圈子中通常被读做“C加加”,而西方的程序员通常读做“C plus plus”。涨姿势了

当Python解释器从我们的输入中解析a ++符号时,会用以下方式进行解释:

由于二进制+运算符是加法运算符,因此a ++将被视为a,+和+。但是Python期望第一个+运算符之后的数字。因此,它将在a ++上给出语法错误,因为第二个+不是数字。

而++ a则会用以下方式进行解释:

  • Python中的一元+运算符指的是身份运算符。这只是返回整数。这就是为什么它是对整数的身份运算
  • 例如,+ 5的值就是5,而+ -5的值是-5。这是一元运算符,适用于实数
  • ++ a将被解析为+和+ a,但是第二个+ a再次被视为(+ a),因此,+(+(a))简单地计算为a。
  • 因此,即使我们想将a的值增加1,我们也无法使用++符号来实现,因为这种运算符不存在。

因此,我们必须使用+ =运算符进行这种增量。

  1. a += 1 
  2. a -= 1 

+=操作是如何进行的呢?

您可能会认为,由于存在=符号,因此它可能是赋值语句。但是,这不是常规的赋值语句。这称为增强的赋值语句。(常规赋值操作的Plus版)

在常规赋值语句中,首先计算右侧,然后再将其赋给左侧。

  1. # 2 + 3 的结果是5,然后才将结果5分配给左边的引用 
  2. a = 2 + 3 

但是,在增强的赋值语句中,首先操作的是左侧,然后计算右侧。这样做是为了使更新后的值可以就地写入左侧。(具体的赋值内存分析后续的文章会涉及到)

  1. # 读取a的值,然后就地添加3 
  2. a += 3 

这是不使用a = a + 1这样的重新分配语句而增加变量的唯一方法。但是,在这里,总的来说,该选项无关紧要,因为解释器将在运行时优化代码。

原文链接:https://www.toutiao.com/a6991294794387489311/