C/C++/C#/Python:数据类型比较

  1. 云栖社区>
  2. 博客>
  3. 正文

C/C++/C#/Python:数据类型比较

oldpan 2017-08-18 22:00:02 浏览1871
展开阅读全文

C/C++/C#/Python这四种语言,由低级到高级,代表了计算机编程语言的一个发展流程,前两种编译型语言大家可能比较熟悉,在大学阶段都基本了解过。而后两种解释型语言,只有特别专业才会去学习(软件设计、网络服务器),在这里,我们通过对这四种语言进行纵向的比较。先从最简单的数据类型开始,以及相关语法,编译解释环境,相同点简略,重点突出,由浅到深去系统梳理一遍,成为一个比较合格的Polylot programmer。当然因为四种语言涉及到的东西很多,所以只挑经常会使用的东西进行梳理,欢迎大家批评指正。

2017编程语言排行榜

当然,重点学习一门编程语言并且精通是必要的,广而不精是众多程序员的通病,但是在现在社会发展飞快的今天,编程语言也在不断竞争发展,名次变化也时常出现。学会适时掌握一门新的语言去适应新的潮流也是有必要的,其实只要掌握精通一门基本语言,其他的语言的学习难度也会降低,而最后你最终青睐哪种语言,就仁者见仁智者见智了。(编程语言第一名的仍然是java,但相比去年有了下降,一些新兴语言也在不断发展)
这里先不讲述这四种语言的发展,有兴趣的可以先查查百度或者维基百科,自行了解。
以下讲解如果有错误,请大家及时告知,我会修改,谢谢!
(以下程序执行环境分别为:C/C++:Codeblocks、C#:VS、Python:pycharm)

数据类型的区别

数据类型是我们编程时必须了解的内容,不论在处理数据,或者算法,执行命令,都需要数据的参与,而数据类型的了解和掌握则是一系列操作的基础

简单类型:布尔型

简单类型即拥有两个值0和1的类型,一般我们称之为布尔类型,这个类型四种语言中都存在,也是程序流程中用于判断,标记常用的一种类型
1、在C语言中这个类型是在C99标准之后才有,必须包含stdbool.h头文件才可以使用

#include <stdio.h>
#include <stdbool.h>

int main()
{
    printf("The size of bool_type is %d",sizeof(bool));
    return 0;
}

很显然,编译结果为1,因为布尔类型只占一位
或者你可以用枚举类型自己定义一个布尔类型

typedef enum{FALSE,TRUE}Flag;

2、C++语言与C语言类型,布尔类型关键词也为bool,因为C++为C的超集,在C能运行的程序在C++中都可以运行,布尔型C与C++几乎是一样的。
3、C#中布尔类型也叫bool型。
4、Python中因为不需要定义类型,直接赋予Ture或者False就可以

>>>a = True
>>>print(a)
True
>>>print(type(a))
<class 'bool'>

整型家族

1、C语言与C++语言中整型种类类似

类型 范围
char 0-255
unsigned char -128-127
int 0-65535
unsigned int -32768-32767
short int -32768-32767
unsigned short int 0-65535
unsigned long int -2147483648-2147483647
long int 0-4294967295

其中int类型的位数是缺省的,根据编译器的变化而变化,可能为16位也可能为32位,在老式电脑的编译器中或者16位的单片机芯片中可能为16位,现在在大多数的电脑中应该都为4个字节32位。
为了便于满足所有计算机的要求,C与C++提供了一种灵活的标准,就是保证最少长度,是由C语言借鉴来的。
另外,C++相比C又新增了一种类型long long,为8个字节。

int main()
{
    cout<<sizeof(long long)<<endl;
}

显然结果为8
2、C#中为了简化运算,方便数据处理,将数据分为以下几个类型

类型 范围
byte 0-255
sbyte -128-127
ushort 0-65535
short -32768-32767
int -2147483648-2147483647
uint 0-4294967295
long -9,223,372,036,854,775,808-9,223,372,036,854,775,807
ulong 0-18,446,744,073,709,551,615
char 0-65535

C#中对类型名称都进行了简化处理方便开发者的使用,其中uint即C语言中的unsigned int 而在C#关键词都进行了化简(其实在C语言C++中你可以自定义类型关键字,与C#一样也是可以的),与C不同的是char表示一个16位的整型,为Unicode字符。
3、Python中整型依然不用定义,直接赋值即可,不带小数点的赋值就是整型,理论上支持无限大的整数

a = 123123123123123123123
type(a)
<class 'int'>
b = -12323123123123123123123
type(b)
<class 'int'>

浮点型家族

1、C和C++的浮点类型一样分为float、double、long double,其中float只收32位、double只收48位,且不少于float,long double至少和double一样多。至于具体有效位和小数位的多少,可以从C或者C++头文件(float.h或者cfloat)中进行查找。

2、C#中三种浮点类型为float、double、decimal三种类型。
其中 float类型可表示精度为 7 位、在大约 1.5 × 10−45 到 3.4 × 1038 的范围内的值。
double类型可表示精度为 15 位或 16 位、在大约 5.0 × 10−324 到 1.7 × 10308 的范围内的值。
至于decimal类型可以表示具有 28 或 29 个有效数字、从 1.0 × 10-28 到大约 7.9 × 1028 范围内的值。decimal类型是采用四舍六入五考虑的银行家舍入法进行计算的。

3、Python如同之前所说,赋值时带入小数点Python解释器便识别为浮点型(python统一为float)

a = 3.1415926
b = -3.1415926
type(a)
<class 'float'>
type(b)
<class 'float'>
c = 3.12312312312312312
type(c)
<class 'float'>

注意,python不同于其他语言,python语言不需要声明变量,只需要写出即相当于定义,其变量的类型与赋值号右面变量类型相同。

组合类型

1、枚举

枚举类型是编程中常见的类型,C/C++中枚举类型的定义方式为

enum animal{pig, dog, cat};
enum animal{pig = 0, dog = 2};

我们常用的定义方式为:

typedef enum{FALSE, TRUE}Flag;
Flag flag = FALSE;

此处flag为0
而在python中,直接进行枚举编程是不可行的,需要导入相应的库才可以进行类似“枚举”的定义:

>>>from enum import Enum
>>>class Animals(Enum):
   ant = 0
   cat = 1
   dog = 2
>>>Animals = Animals.ant
>>>Animals 
<Animals.ant: 0>

网友评论

登录后评论
0/500
评论
oldpan
+ 关注