进制,数据类型,基本类型字面值,基本数据类型运算规则,基本数据类型转化规则

2023-10-13 22:59

本文主要是介绍进制,数据类型,基本类型字面值,基本数据类型运算规则,基本数据类型转化规则,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

进制

计数方式

二进制:0—1;1+1=10  11+1=100 在jdk1.7之前,程序中不允许定义二进制,从jdk1.7之后程序中可以定义二进制数字--以OB/ob作为开头 ob0011 ob101101

八进制0-7 满八进一 7+1=10 17+1=20 77+1=100 要求已0作为开头

十进制 0-9;满十进一,数字如果没有特殊标识,就默认是十进制

十六进制  0-9,a-f,满十六进一8+1=9   9+1=A 39+1=3A  99+1=A0  FF+1=100要求以OX/ox作为开头

1数据类型

扩展:在计算机中是以二进制形式来存储数据,每一位二进制在内存中称之为 位(bit 简写为b),8位=1字节(byte简写为B),1024B=1KB-->MB-->GB-->TB

1.1基本数据类型

1.1.1数值型

整数型

byte字节型     1个字节    27 ~27-1   -128~127

Short 短整型     2个字节  215 ~2151 -32768~32767

Int   整型       4个字节  231 ~231-1

Long 长整型     8个字节  263~263-1   需要在结尾添加L作为表示

自jdk1.7之后可以用_分割

Int a=1_122_123  

浮点型

float    单精度   四个字节    需要在结尾添加f/F作为标识  float a=1.23f -1038~1038

double  双精度   八个字节     默认为double类型      double b=1.256 -10308~10308   double a=4e4  (4*410)  double d=0xsp3表示十六进制的科学计数法 xpy表示x*2y

 

字符型

Char   字符型   两个字节   0-65535  默认编码utf-16  char a=’\u20ac’;

转义字符

制表符‘\t’  回车  ‘\r’  换行‘\n’\--->‘\n’ 单引号 ‘\’’双引号 ‘\”’

扩展:字符在存储过程中需要按照某中规则转化为数字,这种转化称之为编码,记录编码形成的表格形式称之为编码表 -- 码表

IOS-8859-1   西欧码表   1个字节1个字符

Gb2312      国标码      gbk   两个字节一个字符   收录了大部分简体汉字以及一部分繁体汉字

Unicode编码体系  万国码体系  utf-8  三个字节1个字符  utf-16   2个字节1个字符

布尔型
boolean类型两个取值ture和 false

1.2 引用数据类型

接口(interface) 类(class) 数组([ ])

变量定义格式    变量类型 标识符=值;

2标识符命名规则 

  1. 可以使用数字,字母,下划线 $
  2. 不能使用数字开头
  3. 见名知意(驼峰命名法)
  4. 严格区分大小写
  5. 不能使用java关键字

3基本数据类型字面值 

1整型默认是int类型

2小数默认是double类型

3 byte short char三种比int小的整数可以使用范围内的值直接赋值

4字面值后缀 float类型后缀为f double类型后缀为d long类型后缀为l

(后缀不区分大小写)

5字面值前缀 二进制使用0b作为前缀

八进制采用0作为前缀

十进制没有前缀

十六进制采用0x作为前缀

4 基本数据类型转换规则

(除boolean外),此处所说的大小是基本数据类型的取值范围大小:小转大 直接转,大转小 强制转

5基本数据类型运算规则

1相同数据类型运算时结果为同一类型例如3/2=1

2不同数据类型运算时结果为大类型

3 浮点数特殊值,0/0系统报错浮点型除以零时正数除以0则为正无穷大  负数除以0则为负无穷小,0.0/0结果为 NaN not a number

4浮点类型结果不准确

5 当整数运算超过其所在类型的取值范围之后会出现溢出  例如System.out.println(300000000*60*60*24*365); 由于字面值整型默认为int其结果已经超出int取值范围 System.out.println(300000000*60*60*24*365L);也是错误写法,在进行第一次运算的时候其结果已经超过int的取值范围结果也不准确, 正确写法应该是 System.out.println(300000000L*60*60*24*365);

小练习

1 在控制台打印  泡泡今年3岁了月薪99999.99感慨java是世界上最好的语言

代码

运行结果

练习二

在控制台打印除boolean类型外 其他七种基本数据类型的最大值与最小值

/*
本类用来测试几种基本类型的取值范围*/public class TestTypeScope {public static void main(String[] args) {int maxValue = Integer.MAX_VALUE;byte maxValue1 = Byte.MAX_VALUE;short maxValue2 = Short.MAX_VALUE;long maxValue3 = Long.MAX_VALUE;float maxValue4 = Float.MAX_VALUE;double maxValue5 = Double.MAX_VALUE;byte minValue = Byte.MIN_VALUE;short minValue1 = Short.MIN_VALUE;int minValue2 = Integer.MIN_VALUE;long minValue3 = Long.MIN_VALUE;float minValue4 = Float.MIN_VALUE;double minValue5 = Double.MIN_VALUE;char maxValue6 = Character.MAX_VALUE;char minValue6 = Character.MIN_VALUE;/*
boolean 测试布尔类型*/boolean b1=true;//      真为1boolean b2=false;//     假为0//ctrl+alt+向下键快速向下复制一行 如果翻转屏幕 禁用系统快捷键//ctrl+f 查找替换replace AllSystem.out.println("byte最大值为:\t"+maxValue1+"\tbyte的最小值为:\t"+minValue);System.out.println("short最大值为:\t"+maxValue2+"\tshort的最小值为:\t"+minValue1);System.out.println("int最大值为:\t"+maxValue+"\tint的最小值为:\t"+minValue2);System.out.println("long最大值为:\t"+maxValue3+"\tlong的最小值为:\t"+minValue3);System.out.println("float最大值为:\t"+maxValue4+"\tfloat的最小值为:\t"+minValue4);System.out.println("double最大值为:\t"+maxValue5+"\tdouble的最小值为:\t"+minValue5);System.out.println("char最大值为:\t"+maxValue6+"\tchar的最小值为:\t"+minValue6);/*测试字符类型charchar类型可以保存一个数字/字符/汉字  如果存的是数字,会在打印的时候把对应的字符拿出来ASCII表中规定了0-127对应的字符 128-65535以问号处理*/char c1='a';char c2='中';char c3=97;System.out.println(c1);System.out.println(c2);System.out.println(c3);}
}

运行结果

3.

练习值交换
package cn.tude.basic;import java.util.Scanner;
/*
本类用来练习值交换类*/
public class TestValueExchange {/*main方法程序的入口*/public static void main(String[] args) {Scanner scanner=new Scanner(System.in);System.out.println("请输入第一个数字");int a=scanner.nextInt();System.out.println("请输入第二个数字");int b=scanner.nextInt();System.out.println("您输入的第一个数字为"+a);System.out.println("您输入的第二个数字为"+b);//交换过程int temp;temp=a;//用b的值覆盖掉a的值a=b;//用temp覆盖掉b的值b=temp;System.out.println("反转之后第一个数的值为"+a);System.out.println("反转之后第二个数-的值为"+b);//c赋值给tee之后为什么打印c c的值为1//c的值赋值给tee之后c的值c的值不变///* int c=1,tee;tee=c;System.out.println(c);*/}
}

运行结果

这篇关于进制,数据类型,基本类型字面值,基本数据类型运算规则,基本数据类型转化规则的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/206434

相关文章

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

Java文件与Base64之间的转化方式

《Java文件与Base64之间的转化方式》这篇文章介绍了如何使用Java将文件(如图片、视频)转换为Base64编码,以及如何将Base64编码转换回文件,通过提供具体的工具类实现,作者希望帮助读者... 目录Java文件与Base64之间的转化1、文件转Base64工具类2、Base64转文件工具类3、

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

如何将二进制文件流转化为MockMultipartFile文件

《如何将二进制文件流转化为MockMultipartFile文件》文章主要介绍了如何使用Spring框架中的MockMultipartFile类来模拟文件上传,并处理上传逻辑,包括获取二进制文件流、创... 目录一、名词解释及业务解释1.具体业务流程2.转换对象解释1. MockMultipartFile2

关于Gateway路由匹配规则解读

《关于Gateway路由匹配规则解读》本文详细介绍了SpringCloudGateway的路由匹配规则,包括基本概念、常用属性、实际应用以及注意事项,路由匹配规则决定了请求如何被转发到目标服务,是Ga... 目录Gateway路由匹配规则一、基本概念二、常用属性三、实际应用四、注意事项总结Gateway路由

Redis 多规则限流和防重复提交方案实现小结

《Redis多规则限流和防重复提交方案实现小结》本文主要介绍了Redis多规则限流和防重复提交方案实现小结,包括使用String结构和Zset结构来记录用户IP的访问次数,具有一定的参考价值,感兴趣... 目录一:使用 String 结构记录固定时间段内某用户 IP 访问某接口的次数二:使用 Zset 进行

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(