Java基础回顾——数据类型

文章目录

  • 基本数据类型
  • 引用类型
    • 数组类型
      • 遍历数组
      • 排序
      • 多维数组
  • 常量
  • var关键字
  • 四则运算
  • 移位操作
  • 位运算
  • 类型自动提升和强制转型
  • 浮点数运算
  • 三元运算符

内容摘自https://www.liaoxuefeng.com/wiki/1252599548343744/1255883729079552

基本数据类型

  • 整数类型:byte,short,int,long
  • 浮点数类型:float,double
  • 字符类型:char
  • 布尔类型:boolean

计算机内存的最小存储单元是字节byte,一个字节就是8个二进制数,即8个bit,它的二进制表示范围从00000000~11111111,换算成十进制是0 ~ 255,换算成十六进制00 ~ ff

不同数据类型占用的字节数不同
在这里插入图片描述byte:-128 ~ 127
short: -32768 ~ 32767
int: -2147483648 ~ 2147483647
long: -9223372036854775808 ~ 9223372036854775807

        int test=123;long test2=123L;float f=3.14f;double d=3.1415;boolean b=1==2;char a='A';char zh='中';

引用类型

除了基本类型的变量,剩下的都是引用类型,例如String,数组类型…

String s = "hello";

数组类型

数组所有元素初始化为默认值,整型0,浮点型0.0,布尔false

数组一旦创建,大小不可改变

int[] ns = new int[5];
ns[0] = 68;
ns[1] = 79;
ns[2] = 91;
ns[3] = 85;
ns[4] = 62;//ns.lengthint[] ns = { 68, 79, 91, 85, 62 };int[] ns;
ns = new int[] { 68, 79, 91, 85, 62 };

遍历数组

int[] ns = { 68, 79, 91, 85, 62 };
for(int i=0;i<ns.length;i++){int n=ns[i];System.out.println(n);
}for(int n : ns){System.out.println(n);
}

排序

常用的排序算法有冒泡排序、插入排序和快速排序等。

JDK内置了排序功能,Arrays.sort()

import java.util.Arrays;public class Datatype {public static void main(String[] args) {int[] ns = new int[5];ns[0] = 68;ns[1] = 79;ns[2] = 91;ns[3] = 85;ns[4] = 62;for(int n : ns){System.out.print(n+",");}System.out.println();Arrays.sort(ns);for(int n : ns){System.out.print(n+",");}}
}
//68,79,91,85,62,
//62,68,79,85,91,

多维数组

int[][] ns = {{ 1, 2, 3, 4 },{ 5, 6, 7, 8 },{ 9, 10, 11, 12 }
};int[][][] ns = {{{1, 2, 3},{4, 5, 6},{7, 8, 9}},{{10, 11},{12, 13}},{{14, 15, 16},{17, 18}}
};

常量

定义变量时,如果加上final修饰符,这个变量就变成了常量

final double PI=3.14;

常量在定义时进行初始化后就不可再次赋值,再次赋值会导致编译错误。

var关键字

Java10之后支持var关键字

有时候类型名字太长,

StringBuilder sb = new StringBuilder();

这个时候,如果想省略变量类型,可以使用var关键字:

var sb = new StringBuilder();

实际上会自动变成:

StringBuilder sb = new StringBuilder();

四则运算

整数的除法只保留结果的整数部分,%表示求余运算

int x=3/2;//1
int y=3/2;//1

溢出
整数存在范围限制,如果计算结果超出了范围,就会产生溢出,溢出不会出错,会得到一个奇怪的结果

        int x = 2147483640;int y = 15;int sum = x + y;System.out.println(sum); // -2147483641

移位操作

https://blog.csdn.net/fengqing5578/article/details/88224394
左移<< :就是该数对应二进制码整体左移,左边超出的部分舍弃,右边补零。举个例子:253的二进制码1111 1101,在经过运算253<<2后得到1111 0100。很简单

右移>> :该数对应的二进制码整体右移,左边的用原有标志位补充,右边超出的部分舍弃。

无符号右移>>> :不管正负标志位为0还是1,将该数的二进制码整体右移,左边部分总是以0填充,右边部分舍弃。

正数的左移与右移,负数的无符号右移,就是相应的补码移位所得,在高位补0即可。 负数的右移,就是补码高位补1,然后按位取反加1即可。

自己写的测试

public class Datatype {public static void main(String[] args) {
//        int n=7;// 00000000 00000000 00000000 00000111 = 7
//        int a=n >> 1;// 00000000 00000000 00000000 00000011 = 3
//        int b=n >> 2;// 00000000 00000000 00000000 00000001 = 1
//        int c=n >> 3;// 00000000 00000000 00000000 00000000 = 0
//        System.out.println(a+" "+b+" "+c+" ");//        int n=7;// 00000000 00000000 00000000 00000111 = 7
//        int a=n << 1;// 00000000 00000000 00000000 00001110 = 14
//        int b=n << 2;// 00000000 00000000 00000000 00011100 = 28
//        int c=n << 3;// 00000000 00000000 00000000 00111000 = 56
//        System.out.println(a+" "+b+" "+c+" ");// 负数的原码到补码:符号位不变,其他取反加1// 负数的补码到原码:符号位不变,其他取反加1// 移位,右移,移补码,符号位不变,左边补1//        int n=-7;
//        //原码10000000 00000000 00000000 00000111 = 7
//        //补码11111111 11111111 11111111 11111001
//        int a=n >> 1;
//        //补码11111111 11111111 11111111 11111100
//        //原码10000000 00000000 00000000 00000110 = -4
//        int b=n >> 2;
//        //补码11111111 11111111 11111111 11111110
//        //原码10000000 00000000 00000000 00000010 = -2
//        int c=n >> 3;
//        //补码11111111 11111111 11111111 11111110
//        //原码10000000 00000000 00000000 00000001 = -1
//        System.out.println(a+" "+b+" "+c+" ");//        int n=-536870912;
//        //原码10100000 00000000 00000000 00000000 = -536870912
//        //补码11100000 00000000 00000000 00000000
//        int a=n >> 1;
//        //补码11110000 00000000 00000000 00000000
//        //原码10001000 00000000 00000000 00000000 = -268435456
//        int b=n >> 2;
//        //补码11111000 00000000 00000000 00000000
//        //原码10000100 00000000 00000000 00000000 = -134217728
//        int c=n >> 3;
//        //补码11111100 00000000 00000000 00000000
//        //原码10000010 00000000 00000000 00000000 = -67108864
//        System.out.println(a+" "+b+" "+c+" ");//        int n=-536870912;
//        //原码10100000 00000000 00000000 00000000 = -536870912
//        //补码11100000 00000000 00000000 00000000
//        int a=n << 1;
//        //补码11000000 00000000 00000000 00000000
//        //原码10100000 00000000 000000000 00000000 = -1073741824
//        int b=n << 2;
//        //补码11000000 00000000 00000000 00000000
//        //原码10000000 00000000 00000000 00000000 = -2147483648
//        int c=n << 3;
//        //补码10000000 00000000 00000000 00000000
//        //原码10000000 00000000 00000000 00000000 = 0
//        System.out.println(a+" "+b+" "+c+" ");}
}

位运算

位运算是按位进行与、或、非和异或的运算

与运算:同时为1,结果为1

n = 0 & 0; // 0
n = 0 & 1; // 0
n = 1 & 0; // 0
n = 1 & 1; // 1

或运算:只要任意为1,结果为1

n = 0 | 0; // 0
n = 0 | 1; // 1
n = 1 | 0; // 1
n = 1 | 1; // 1

非运算:0和1互换

n = ~0; // 1
n = ~1; // 0

异或运算:两个数不同,结果为1 ,否则0

n = 0 ^ 0; // 0
n = 0 ^ 1; // 1
n = 1 ^ 0; // 1
n = 1 ^ 1; // 0

类型自动提升和强制转型

在运算过程中,如果参与运算的两个数类型不一致,那么计算结果为较大类型的整型。例如,short和int计算,结果总是int,原因是short首先自动被转型为int

public class Main {public static void main(String[] args) {short s = 1234;int i = 123456;int x = s + i; // s自动转型为intshort y = s + i; // 编译错误!}
}

也可以将结果强制转型,即将大范围的整数转型为小范围的整数。强制转型使用(类型),例如,将int强制转型为short

int i = 12345;
short s = (short) i; // 12345

超出范围的强制转型会得到错误的结果,原因是转型时,int的两个高位字节直接被扔掉,仅保留了低位的两个字节

浮点数运算

浮点数运算和整数运算相比,只能进行加减乘除,不能做位运算和移位运算

浮点数虽然表示的范围大,但是浮点数常常无法精确表示

比如:浮点数0.1在计算机中无法精确表示,因为十进制的0.1换算成二进制是一个无限循环小鼠,无论用float还是double,都只能存储一个0.1的近似值,但0.5可以精确地表示

        double x = 1.0 / 10;double y = 1 - 9.0 / 10;// 观察x和y是否相等:System.out.println(x);System.out.println(y);
//0.1
//0.09999999999999998

比较两个浮点数是否相等常常会出现错误的结果。正确的比较方法是判断两个浮点数之差的绝对值是否小于一个很小的数

// 比较x和y是否相等,先计算其差的绝对值:
double r = Math.abs(x - y);
// 再判断绝对值是否足够小:
if (r < 0.00001) {// 可以认为相等
} else {// 不相等
}

三元运算符

三元运算符b ? x : y,它根据第一个布尔表达式的结果,分别返回后续两个表达式之一的计算结果。

int n=-100;
int x=n>=0 ? n : -n;
System.out.println(x);
//100

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/277863.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网络协议 - DNS 相关详解

网络协议 - DNS 相关详解 DNS简介域名层级结构域名服务器 DNS 解析流程为什么DNS通常基于UDP DNS 查询dig 查询host查询nslookup查询whois查询在线工具查询 DNS 调度原理地理位置调度不准确规则变更生效时间不确定高可用 DNS 安全相关什么是DNS劫持什么是DNS污染为什么要DNS流量…

代付系统源码/第三方API代付系统源码/手工代付系统/批量代付系统/集成QQ微信支付宝API代付系统

源码介绍&#xff1a; 这是一款代付系统源码、API代付系统源码&#xff0c;也是手工代付系统、批量代付系统和第三方API代付系统&#xff0c;它是QQ微信支付宝API代付系统&#xff0c;余额充值接口集成易支付。 系统以0S秒下发&#xff0c;支持支付宝、微信、QQ等主流支付通道…

QT笔记(节选)具体图片等下载资源

QT笔记&#xff08;节选&#xff09;具体图片等下载资源 根据b站视频做的笔记&#xff1a; https://www.bilibili.com/video/BV1g4411H78N?p44&spm_id_frompageDriver&vd_sourcea3e6a48ccd3d7d1f969f662653ed68c9 qt是一个跨平台的c图形用户界面应用程序框架&#x…

从最近爆火的ChatGPT,我看到了电商的下一个形态

爆火的ChatGPT似乎让每个行业有了改造的可能性&#xff0c;电商行业也不例外。 在讨论了很多流量红利消失的话题后&#xff0c;我们看到互联网电商行业不再性感&#xff0c;从淘宝天猫&#xff0c;京东&#xff0c;到拼多多&#xff0c;再到抖音&#xff0c;快手&#xff0c;电…

MacOS下载配置OpenCV

主要参考的是OpenCV官方的这篇文章&#xff1a;OpenCV: Installation in MacOS 安装OpenCV需要下载一些安装包&#xff1a;CMake3.9、Git、Python这些我之前已经下载好&#xff0c;这里就不过多阐述了&#xff0c;自行百度安装即可 1.从Git库获取OpenCV&#xff1a; git clon…

C++1114新标准——模板模板参数(Template Template Parameter)、using

系列文章目录 C11&14新标准——Variadic templates&#xff08;数量不定的模板参数&#xff09; C11&14新标准——Uniform Initialization&#xff08;统一初始化&#xff09;、Initializer_list&#xff08;初始化列表&#xff09;、explicit C11&14新标准—— d…

SpringBoot中日志的使用log4j2

SpringBoot中日志的使用log4j2 1、log4j2介绍 Apache Log4j2 是对 Log4j 的升级&#xff0c;它比其前身 Log4j 1.x 提供了重大改进&#xff0c;并提供了 Logback 中可用的许多改 进&#xff0c;同时修复了 Logback 架构中的一些问题&#xff0c;主要有&#xff1a; 异常处理…

SpringBoot+线程池实现高频调用http接口并多线程解析json数据

场景 SpringbootFastJson实现解析第三方http接口json数据为实体类(时间格式化转换、字段包含中文)&#xff1a; SpringbootFastJson实现解析第三方http接口json数据为实体类(时间格式化转换、字段包含中文)-CSDN博客 Java中ExecutorService线程池的使用(Runnable和Callable多…

如何了解蜘蛛池蚂蚁SEO

蜘蛛池是一种基于搜索引擎优化的技术手段&#xff0c;通过模拟蜘蛛爬行行为来提高网站在搜索引擎中的排名&#xff0c;从而增加网站的流量和曝光率。 编辑搜图 如何联系蚂蚁seo&#xff1f; baidu搜索&#xff1a;如何联系蚂蚁SEO&#xff1f; baidu搜索&#xff1a;如何联…

vivado约束方法6

生成的时钟 定时约束向导建议在的输出上创建一个生成的时钟顺序单元&#xff0c;当它直接或通过驱动其他顺序单元的时钟引脚时一些互连逻辑。与PLL或MMCM不同&#xff0c;用户逻辑不能将主时钟&#xff0c;因此向导仅提供指定除法系数的选项&#xff0c;如中所示如下图所示&am…

CSS中神奇的filter属性

CSS是Web开发中不可或缺的一部分&#xff0c;它可以帮助开发者在页面上添加各种各样的样式和效果。其中一个比较神奇的CSS属性就是filter&#xff0c;它可以让我们实现各种有趣的图形处理效果。 一、filter属性的基础 filter属性是CSS中用于对元素进行图形效果处理的属性之一…

LeetCode-42. 接雨水【栈 数组 双指针 动态规划 单调栈】

LeetCode-42. 接雨水【栈 数组 双指针 动态规划 单调栈】 题目描述&#xff1a;解题思路一&#xff1a;单调栈&#xff0c;维护一个单调递减栈。每当遇到当前元素大于栈顶元素就出栈&#xff0c;在出栈时更新答案。当遇到出栈的情况&#xff0c;若单调栈栈左边有一个元素则必有…