前言:
目前咱们对“python中支持c语言的自增和自减操作符”可能比较关怀,咱们都需要知道一些“python中支持c语言的自增和自减操作符”的相关资讯。那么小编也在网络上网罗了一些有关“python中支持c语言的自增和自减操作符””的相关资讯,希望看官们能喜欢,同学们一起来学习一下吧!背景知识
对于有C/C++/Java等类C语言背景的人来说,Python的语法有很大的不同。
下面分别是两段功能几乎一致的C++代码和Python代码,主要展示两种语言在语法上的不同,代码正确但质量不高,请见谅。
本文转载自"狂龙ing”的Blog,地址为“"
C++:
#include <stdio.h>class Person{ public: int foo(int num); private: void no(){ }}; int Person::foo(int num){ //example function to show printf("Hello World!\n"); for(int i = 0; i < 10; ++i){ printf("%d\t", i); } printf("\n\n"); if(num > 3){ printf("%d > 3\n", num); }else if(num <3){ printf("%d < 3\n", num); }else{ printf("%d == 3\n", num); } num = num >= 3 ? 10: -3; while(num > 3){ --num; } switch(num){ case 1: printf("The number is %d at the end!\n", num); break; case 2: printf("The number is %d at the end!\n", num); break; case 3: printf("The number is %d at the end!\n", num); break; default: printf("The number is %d at the end!\n", num); } /* Test try...catch */ try{ throw 20; }catch(int e){ printf("An exception occurred. Exception Nr. %d\n", e); } } int main(int argc, const char *argv[]){ Person *p = new Person(); p->foo(10); delete p; p = NULL; return 0;}
学习从来不是一个人的事情,要有个相互监督的伙伴,工作需要学习C/C++或者为了入行、转行学习C/C++的伙伴可以私信回复小编“学习”领取全套免费C/C++学习资料、视频
Python:
#!/usr/bin/env python class Person: def foo(self, num): """docstring for foo example function to show """ print 'Hello World!' for i in range(0,10): print "%d\t" %i else: print "There is no element" print "\n\n" if num > 3: print "%d > 3\n" % num elif num < 3: print '%d < 3\n' % num else: print "%d == 3\n" % num while num > 3: num -= 1 else: print "%d <= 3" % num #Test try...except try: raise Exception(20) except Exception as e: print "An exception occurred. Exception Nr. %d" % e.message def no(self): pass if __name__ == '__main__': p = Person() p.foo(10) p.foo(num = -2) del p p = None
语法差别说明
我把两种语言语法的差别分为以下几类,并参考上面两段代码进行显示。
代码段:
类C语言使用小括号( )和花括号{ }组织代码段。比如函数定义、判断结构、循环结构等。Python使用冒号(:)和缩进的方式来组织代码段
注释:
类C语言注释使用//进行单行注释,/* */进行跨行注释Python使用#进行单行注释, ''' '''或""" """进行多行注释
空代码段:
类C语言使用一个空的{ }代表空代码段Python使用缩进组织代码段,所以不能为空,不过可以使用pass代码空语句
等价语句:
字符串定义:
类C语言使用双引号“”来定义字符串,单引号‘’定义单个字符类型Python没有单个字符类型,单引号和双引号等价,都可以定义字符串
函数定义:
类C语言:返回类型 函数名(参数列表){函数语句},比如int foo(int num){return num*2;}
Python:
def 函数名(参数列表):
函数语句
Python缺少的语法特性:
switch语句:switch在类C语言中使用很多,但是Python没有switch语句,也没有等价的语法。Python官方文档解释原因Design and History FAQ三元操作符(condition ? expr1 : expr2):相信很多人都喜欢使用这种简洁的表达方式,不过Python也不支持。类定义中的访问控制符(public, protected, private):访问控制符可以增强类的封装特性,在C++和Java中都用的很多。自增/自减操作符(++/--):类C语言里离不开的东东,特别是循环结构中。
Python新增语法特性:
in:判断一个元素是否属于一个容器(list, set, dict, tuple等),属于则返回True,不属于则返回False按名传参:类C语言都是使用按位传参,Python支持按位传参和按名传参两种方式。比如 p.foo(num = -2),num是形参的名字
总结
对于熟悉类C语言的程序员来说,Python语法有很大的不同,一开始会不太习惯,一旦习惯了之后就会慢慢体会到Python语言的优美之处。
主要参考文献
百度百科