【C#vsPython·第一阶段】int、string、bool?Python 的类型世界有点不一样
在 C# 里int最大能表示 2,147,483,647约 21 亿。超过这个数对不起溢出了你得用long。在 Python 里2 ** 100直接算连眼都不眨一下。Python 的int没有上限想算多大算多大。当我第一次用 Python 算2 ** 1000的时候我震惊了——这在 C# 里得用BigInteger在 Python 里就是个普通的int。今天咱们来聊聊基本数据类型——C# 的固定大小 vs Python 的任意精度。数值类型C# 的数值类型像一排不同大小的箱子byte a 255; // 8位0-255 short b 32767; // 16位 int c 2147483647; // 32位最常用 long d 9223372036854775807; // 64位 float e 3.14f; // 32位 double f 3.14; // 64位最常用 decimal g 3.14m; // 128位金融计算 // 大整数需要 using System.Numerics BigInteger h BigInteger.Parse(999999999999999999999999999999);Python 就简单粗暴——一个int搞定所有整数a 255 b 32767 c 2147483647 d 9223372036854775807 e 2 ** 1000 # 直接算没问题 # 浮点数 f 3.14 # 64位双精度 g 3.14e10 # 科学计数法 # 复数C# 没有的 h 3 4j # Python 原生支持复数对比项C#Python小整数byte,short,int,long统一的int大整数需要BigInteger原生支持无上限浮点数float,double,decimal统一的float64位复数需要Complex结构体原生支持3 4j溢出检查会溢出默认不会溢出C# 的程序员得操心该用 int 还是 longPython 的程序员根本不用想——反正不会溢出。为什么 Python 的 int 没有上限因为 Python 的 int 是任意精度整数它会动态分配内存来存储大数。而 C# 的 int 是固定宽度整数存储在 CPU 寄存器里所以有上限。真实场景在密码学和大数计算中Python 的 int 无上限特性非常有用。比如计算 RSA 密钥Python 直接用pow(a, b, m)就行C# 得用BigInteger.ModPow()。布尔类型C# 的布尔就是布尔bool a true; bool b false; bool c true false; // false bool d true || false; // true bool e !true; // false // 不能直接当数字用 int x (int)true; // 需要显式转换结果是 1Python 的布尔...就是整数a True b False c True and False # False d True or False # True e not True # False # 布尔就是整数 x True True # 2 y False * 10 # 0 z True * 5 False # 5特性C#Python布尔值true/false小写True/False首字母大写布尔运算,||,!and,or,not布尔参与运算需要显式转换自动当整数用0/1Python 的True就是 1False就是 0所以True True 2。这不是 bug是 feature。为什么 Python 这样设计因为 Python 的布尔类型是整数的子类bool是int的子类。这样设计的好处是布尔值可以直接参与数学运算不需要显式转换。真实场景在数据分析中经常需要统计满足条件的数量。Python 的布尔可以直加data [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] count sum(x 5 for x in data) # 5True 的个数C# 得这样写var data new[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; int count data.Count(x x 5); // 5字符串类型C# 的字符串string s1 Hello; string s2 World; string s3 s1 s2; string s4 ${s1} {s2}; // 插值 int len s1.Length; // 5 string upper s1.ToUpper(); // HELLO string sub s1.Substring(1, 3); // ellPython 的字符串s1 Hello s2 World s3 s1 s2 s4 f{s1} {s2} # f-string推荐 length len(s1) # 5函数不是属性 upper s1.upper() # HELLO sub s1[1:4] # ell切片语法对比项C#Python类型名string首字母大写str全小写长度s.Length属性len(s)函数字符串插值$Hello {name}fHello {name}子串s.Substring(1, 3)s[1:4]切片大小写s.ToUpper()s.upper()C# 的长度是属性s.LengthPython 的长度是函数len(s)。C# 用方法调用Python 用切片语法——各有各的优雅。为什么 Python 用len()而不是.length因为 Python 的哲学是**统一接口**。所有序列类型列表、元组、字符串、字典都用len()函数而 C# 的.Length是数组和字符串特有的。空值C# 的空值有可空类型的概念string s null; int? x null; // 可空类型 if (s null) { } // 值类型不能为 null除非用 NullableT // int y null; // 编译错误Python 没有可空类型任何变量都可以是 Nones None x None # Python 没有可空类型的概念 if s is None: print(s 是 None) # 但要注意类型提示 from typing import Optional def greet(name: Optional[str] None) - str: if name is None: return Hello, World! return fHello, {name}!C# 的值类型默认不能为 null得用NullableT才行。Python 的任何变量都可以是 None简单粗暴。为什么 Python 用is None而不是 None因为None是一个单例对象is比较的是对象身份比较的是值。用is更高效也更符合 Python 的惯例。类型检查和转换// C# 类型检查 int x 5; bool isInt x is int; // true Type type x.GetType(); // System.Int32 // C# 类型转换 string s 123; int n int.Parse(s); // 123 bool success int.TryParse(s, out int result); // 安全转换# Python 类型检查 x 5 is_int isinstance(x, int) # True type_name type(x).__name__ # int # Python 类型转换 s 123 n int(s) # 123 # 安全转换没有 TryParse需要 try-except def safe_int(s): try: return int(s), True except ValueError: return None, FalseC# 有TryParse这种安全转换Python 没有——想安全转换就得用try-except。真实场景在处理用户输入时C# 的TryParse非常方便string input Console.ReadLine(); if (int.TryParse(input, out int number)) { Console.WriteLine($你输入的是: {number}); } else { Console.WriteLine(请输入有效的数字); }Python 得这样写input_str input(请输入数字: ) try: number int(input_str) print(f你输入的是: {number}) except ValueError: print(请输入有效的数字)设计哲学C# 的哲学是类型精确——不同大小的整数用不同类型开发者可以选择合适的类型内存控制更精细。Python 的哲学是简化类型——一个int搞定所有整数开发者不需要纠结该用int还是long数学友好复数原生支持。C# 像是给你一排不同大小的箱子你得自己选合适的 Python 像是给你一个无限大的箱子随便装。迁移指南C# 开发者最容易犯的错以为 Python 的 int 会溢出不会Python 的 int 是任意精度的忘记布尔就是整数True True 2是合法的以为None等于空字符串None、、0、[]是不同的过度使用类型注解Python 不需要像 C# 那样到处写类型以为 Python 没有复数Python 原生支持复数3 4j坑点提醒True True 2——在 Python 里布尔就是整数print(True True) # 2 print(True * 10) # 10 print(False 1) # 1浮点数精度——和 C# 一样Python 的浮点数也有精度问题print(0.1 0.2) # 0.30000000000000004 print(0.1 0.2 0.3) # FalseNone 不等于空——None 和空字符串/空列表是不同的print(None ) # False print(None []) # False print(None is None) # True用 is 比较一句话总结Python 的 int 没有大小限制True True 等于 2这就是鸭子类型的世界。下一篇咱们来聊聊运算符——Python 的幂运算**让数学公式可以直接翻译成代码链式比较0 x 10更是 C# 梦寐以求的语法糖。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2614492.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!