重学Java的第一章

news2025/1/31 18:01:54

1.写在前面

今年的行情很差,差到很多人都没有办法找到工作,博主也是一个菜逼,找了一家小破公司,导致我那段时间很迷茫,也是也很焦虑,思考了很多,觉得我自己学的已经够多了,但是每一次面试,博主都是没有好好的准备的,导致找到的工作也不是很好,现在这家公司也不是很好,领导天天PUA我,这次没有像之前一样,直接离职,博主知道现在的行情,都是混口饭。我开始反思,我发现我学的东西很多,都是没有串起来,导致我整个的知识体系也没有。那么就打碎掉吧。从头再来,不丢人。于是重学Java吧!玩了一年多了,突然发现重新捡起来学习,有点难!

2.为什么需要变量

由于我们是有基础的,不需要去了解什么Java的历史,如果你们想了解的话,可以去看看对应的Java的历史,博主这儿就不做过多的赘述。直接从变量开始,不管你们学过还是没有学过。我相信总有一些细节你们没有记住。

看到这个标题,你们第一时间想到了什么?为什么需要变量?我们都知道在计算机中所有的所有的数据都是通过二进制存储起来的。那么问题来了?这些数据是怎么存储的?怎么找到的?这儿博主想到了一句话,从汇编的一本书上看到的一句话**数据的两大的要素,一个是地址,还有一个就是长度。**这句话,博主这儿不做过多的解释,通过你们读取这篇文章,你们会有更多的体会。

回到刚才的问题,为什么需要变量?

  • 一个程序就是一个世界 (一个程序对计算机来说表示一个世界)
  • 变量是程序的基本组成单位(变量的组成的 类型 名称 值)

计算机程序的基本组成单位都是变量了,而且我们平时不管写什么程序都是需要变量了,而且计算机大部分的时候都是与数据进行打交道,而数据的载体是变量。那么不言而喻,变量的重要性了。

3.变(变化)量(值)的介绍

3.1概念

变量相当于内存中一个数据存储空间的表示, 你可以把变量看做是一个房间的门牌号, 通过门牌号我们可以找到房间, 而通过变量名可以访问到变量(值)。

3.2变量使用的基本步骤

声明变量 赋值

3.3简单的案例

package chapter03;

public class Var02 {
    //编写一个 main 方法
    public static void main(String[] args) {
        //记录人的信息
        int age = 30;
        double score = 88.9;
        char gender = '男';
        String name = "king";
        //输出信息, 快捷键
        System.out.println("人的信息如下:");
        System.out.println(name);
        System.out.println(age);
        System.out.println(score);
        System.out.println(gender);
    }
}

4.变量使用注意事项

  1. 变量表示内存中的一个存储区域[不同的变量,类型不同,占用的空间大小不同]
  2. 该区域有自己的名称[变量名]和类型[数据类型] 这句话就可以回到我们之前说的两大要素,就是地址,长度,其中的变量名我们可以简单的理解为变量名,长度我们可以简单的理解为类型,因为每一种数据的类型的长度都是不一样。因为计算机不知道你存的是什么东西,你只要给它一个地址,然后读取对应的地址的,同时从这个地址对应长度的字节,就能确定这个空间存的是什么东西了。
  3. 变量必须先声明,后使用
  4. 变量在同一个作用域内不能重名
  5. 变量=变量名+值+数据类型
package chapter03;

public class VarDetail {
    //编写一个 main 方法
    public static void main(String[] args) {
        //变量必须先声明, 后使用, 即有顺序
        int a = 50;//int
        System.out.println(a);//50
        //该区域的数据/值可以在同一类型范围内不断变化
        //a = "jack"; //×
        a = 88; //对
        System.out.println(a);//88
        //变量在同一个作用域内不能重名
        //int a = 77;//错误
    }
}

class Dog {
    public static void main(String[] args) {
        int a = 666;//对
    }
}

5.程序中+号的使用

  1. 当左右两边都是数值型时,则做加法运算。
  2. 当左右两边有一方为字符串,则做拼接运算。
  3. 运算顺序,是从左到右。

6.数据类型

在这里插入图片描述

上面的8大基本的数据类型,要烂熟于胸。至于范围后面学习对应的存储的方式再来和大家说为啥是这个范围。

7.整型的使用细节

  1. Java各整数类型有固定的范围和字段长度,不受具体操作系统的影响,以保证Java程序的可移植性。
  2. Java的整型常量默认为int型,声明long型常量须后加l或者L
  3. Java程序中变量常声明为int型,除非不足以表示大数,才使用long
  4. bit:计算机中的最小存储单位。byte:计算机中基本存储单元,1byte=8bit
package chapter03;

public class IntDetail {
    //编写一个 main 方法
    public static void main(String[] args) {
        //Java 的整型常量(具体值) 默认为 int 型, 声明 long 型常量须后加‘l’或‘L’
        int n1 = 1;//4 个字节
        //int n2 = 1L;//对不对?不对
        long n3 = 1L;//对
    }
}

8.浮点类型

  1. 关于浮点数在机器中存放的形式的简单说明,浮点数=符号位+指数位+尾数位
  2. 尾数部分可能丢失,造成精度损失(小数都是近似值)
  3. 与整数类型类似,Java浮点类型也有固定的范围和字段长度,不受操作系统影响
  4. Java的浮点类型的常量默认为double类型,声明float型常量,须后加’f’或‘F’
  5. 浮点型常量有两种表示形式
    • 十进制数形式:如5.12 512.0f .512(必须有小数点)
    • 科学计数法形式:如5.12e2[5.12*10的2次方] 5.12E-2[5.12/10的2次方]
  6. 通常情况下,应该使用double型,因为它比float型更精确。
  7. 浮点数使用陷阱:2.7 和 8.1/3比较
package chapter03;

public class FloatDetail {
    //编写一个 main 方法
    public static void main(String[] args) {
        //Java 的浮点型常量(具体值)默认为 double 型, 声明 float 型常量, 须后加‘f’或‘F'
        //float num1 = 1.1; //对不对?错误
        float num2 = 1.1F; //对的
        double num3 = 1.1; //对
        double num4 = 1.1f; //对
        //十进制数形式: 如: 5.12 512.0f .512 (必须有小数点)
        double num5 = .123; //等价 0.123
        System.out.println(num5);
        //科学计数法形式:如: 5.12e2 [5.12 * 10 的 2 次方 ] 5.12E-2 []
        System.out.println(5.12e2);//512.0
        System.out.println(5.12E-2);//0.0512
        //通常情况下, 应该使用 double 型, 因为它比 float 型更精确。
        //[举例说明]double num9 = 2.1234567851;float num10 = 2.1234567851F;
        double num9 = 2.1234567851;
        float num10 = 2.1234567851F;
        System.out.println(num9);
        System.out.println(num10);
        //浮点数使用陷阱: 2.7 和 8.1 / 3 比较
        //看看一段代码
        double num11 = 2.7;
        double num12 = 2.7; //8.1 / 3; //2.7
        System.out.println(num11);//2.7
        System.out.println(num12);//接近 2.7 的一个小数, 而不是 2.7
        //得到一个重要的使用点: 当我们对运算结果是小数的进行相等判断是, 要小心
        //应该是以两个数的差值的绝对值, 在某个精度范围类判断
        if (num11 == num12) {
            System.out.println("num11 == num12 相等");
        }
        //正确的写法 , ctrl + / 注释快捷键, 再次输入就取消注释
        if (Math.abs(num11 - num12) < 0.000001) {
            System.out.println("差值非常小, 到我的规定精度, 认为相等...");
        }
        //可以通过 java API 来看 下一个视频介绍如何使用 API
        System.out.println(Math.abs(num11 - num12));
        //细节:如果是直接查询得的的小数或者直接赋值, 是可以判断相等
    }
}

8.字符类型

  1. 字符类型可以表示单个字符,字符类型是char,char是两个字节(可以存放汉字),多个字符我们用字符串String
  2. 字符常量是用单引号(‘’)括起来的单个字符
  3. Java中还允许使用转义字符’'来将其后的字符转变为特殊字符型常量。
  4. 在Java中,char的本质是一个整数,在输出时,是Unicode码对应的字符。
  5. 可以直接给char赋一个整数,然后输出时,会按照对应的Unicode字符输出
  6. char类型可以进行运算,相当于一个整数,因为它都对应有Unicode码
package chapter03;

public class CharDetail {
    //编写一个 main 方法
    public static void main(String[] args) {
        //在 java 中, char 的本质是一个整数, 在默认输出时, 是 unicode 码对应的字符
        //要输出对应的数字, 可以(int)字符
        char c1 = 97;
        System.out.println(c1); // a
        char c2 = 'a'; //输出'a' 对应的 数字
        System.out.println((int) c2);
        char c3 = '韩';
        System.out.println((int) c3);//38889
        char c4 = 38889;
        System.out.println(c4);//韩
        //char 类型是可以进行运算的, 相当于一个整数, 因为它都对应有 Unicode 码.
        System.out.println('a' + 10);//107
        //课堂小测试
        char c5 = 'b' + 1;//98+1==> 99
        System.out.println((int) c5); //99
        System.out.println(c5); //99->对应的字符->编码表 ASCII(规定好的)=>c
    }
}

9.编码格式

  1. ASCII(ASCII编码表 一个字节表示,一个128个字符,实际上一个字节可以表示256个字符,只用128个)
  2. Unicode(Unicode 编码表 固定大小的编码 使用两个字节表示字符, 字母和汉字统一都是占用两个字节,这样浪费空间)
  3. utf-8(编码表,大小可变的编码 字母使用1个字节,汉字使用3个字节)
  4. gbk(可以表示汉字,而且范围广,字母使用1个字节,汉字2个字节)
  5. gb2312(可以表示汉字,gb2312 < gbk)
  6. big5码(繁体中文,台湾,香港)

注意:这儿引出了一个问题,就是如果我们用的utf-8的编码,那么汉字就是占用三个字节,而char只占用两个字节,这个是怎么操作的呢?在Java文件中如果声明了char c = '中';,编译后生成的class文件会把转化成Unicode的一种表现方式。

10.布尔类型

  1. 布尔类型也叫boolean类型,boolean类型数据只允许取值true和false,无null
  2. boolean类型占1个字节
  3. boolean类型适用于逻辑运算,一般用于程序流程控制。
package chapter03;

public class Boolean01 {
    //编写一个 main 方法
    public static void main(String[] args) {
        //演示判断成绩是否通过的案例
        //定义一个布尔变量
        boolean isPass = true;//
        if (isPass == true) {
            System.out.println("考试通过, 恭喜");
        } else {
            System.out.println("考试没有通过, 下次努力");
        }
    }
}

11.基本数据类型的转换

11.1自动类型转换

当Java程序在进行赋值或者运算时,精度小的乐行自动转换为精度大的数据类型,这个就是自动类型转换。

在这里插入图片描述

这儿可能有一个疑问就是long不是8字节,而float是4个字节,为啥能自动转换呢?你如果看我前面的范围你会发现,float的范围会比long大,这是为什么呢?这需要了解计算机中的浮点数是怎么存的。

11.2自动类型转换注意和细节

  1. 有多种类型的数据混合运算时,系统首先自动将所有数据转换成容量最大的那种数据类型,然后再进行计算。
  2. 当我们吧精度大的数据类型赋值给精度小的数据类型时,就会报错,反之就会进行自动类型转换。
  3. byte short和char之间不会相互自动转换。
  4. byte short char 他们三者可以计算,在计算时首先转换为int类型
  5. boolean不参与转换
  6. 自动提升原则:表达式结果的类型自动提升为操作数中最大的类型。
package chapter03;

//自动类型转换细节
public class AutoConvertDetail {
    //编写一个 main 方法
    public static void main(String[] args) {
        //细节 1: 有多种类型的数据混合运算时,
        //系统首先自动将所有数据转换成容量最大的那种数据类型, 然后再进行计算
        int n1 = 10; //ok
        //float d1 = n1 + 1.1;//错误 n1 + 1.1 => 结果类型是 double
        //double d1 = n1 + 1.1;//对 n1 + 1.1 => 结果类型是 double
        float d1 = n1 + 1.1F;//对 n1 + 1.1 => 结果类型是 float

        //细节 2: 当我们把精度(容量)大 的数据类型赋值给精度(容量)小 的数据类型时,
        //就会报错, 反之就会进行自动类型转换。
        //
        //int n2 = 1.1;//错误 double -> int

        //细节 3: (byte, short) 和 char 之间不会相互自动转换
        //当把具体数赋给 byte 时, (1)先判断该数是否在 byte 范围内, 如果是就可以
        byte b1 = 10; //对 , -128-127
        // int n2 = 1; //n2 是 int
        // byte b2 = n2; //错误, 原因: 如果是变量赋值, 判断类型
        //
        // char c1 = b1; //错误, 原因 byte 不能自动转成 char
        //
        //

        //细节 4: byte, short, char 他们三者可以计算, 在计算时首先转换为 int 类型
        byte b2 = 1;
        byte b3 = 2;
        short s1 = 1;
        //short s2 = b2 + s1;//错, b2 + s1 => int
        int s2 = b2 + s1;//对, b2 + s1 => int
        //byte b4 = b2 + b3; //错误: b2 + b3 => int
        //
        //boolean 不参与转换
        boolean pass = true;
        //int num100 = pass;// boolean 不参与类型的自动转换
        //自动提升原则: 表达式结果的类型自动提升为 操作数中最大的类型
        //看一道题
        byte b4 = 1;
        short s3 = 100;
        int num200 = 1;
        float num300 = 1.1F;
        double num500 = b4 + s3 + num200 + num300; //float -> double
    }
}

11.3强制类型转换

自动类型转换的逆过程, 将容量大的数据类型转换为容量小的数据类型。 使用时要加上强制转换符 ( ), 但可能造成
精度降低或溢出,格外要注意

  1. 当进行数据的大小 从 大到小,就需要使用到强制转换
  2. 强制符号只针对与最近的操作数有效,往往会使用小括号提升优先级
  3. char类型可以保存int的常量值,但不能保存int的变量值,需要强转
  4. byte和short char类型在进行运算时,当做int类型处理。
package chapter03;

public class ForceConvertDetail {
    //编写一个 main 方法
    public static void main(String[] args) {
        //演示强制类型转换
        //强转符号只针对于最近的操作数有效, 往往会使用小括号提升优先级
        //int x = (int)10*3.5+6*1.5;//编译错误: double -> int
        int x = (int) (10 * 3.5 + 6 * 1.5);// (int)44.0 -> 44
        System.out.println(x);//44
        char c1 = 100; //ok
        int m = 100; //ok
        //char c2 = m; //错误
        char c3 = (char) m; //ok
        System.out.println(c3);//100 对应的字符, d 字符
    }
}

12.基本数据类型和String类型转换

  1. 基本类型转String类型 将基本类型的值+""即可
  2. String类型转成基本数据类型 通过基本类型的包装类调用parseXX方法就可以了。

13.写在最后

-> 44
System.out.println(x);//44
char c1 = 100; //ok
int m = 100; //ok
//char c2 = m; //错误
char c3 = (char) m; //ok
System.out.println(c3);//100 对应的字符, d 字符
}
}


## 12.基本数据类型和String类型转换

1. 基本类型转String类型 将基本类型的值+""即可
2. String类型转成基本数据类型 通过基本类型的包装类调用parseXX方法就可以了。

## 13.写在最后

这篇文章简单的介绍了一下Java的变量,就算我是一个做了几年的开发,但是有些细节还是不太记得了。还是有收获,查漏补缺吧。共勉。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《Lua程序设计》--学习7

数据结构 数组 矩阵和多维数组 不规则数组&#xff1a;数组的数组&#xff0c;也就是所有元素均是另一个表的表 将两个索引合并为一个&#xff1a;声明一个长数组&#xff0c;然后根据 行数*行所拥有的元素个数列数来访问这样 链表 因为表是动态对象&#xff0c;所以在Lua语…

4.7 wait notify - 4.11 多把锁

目录 4.7 wait notify1、为什么需要wait2、原理之wait/notify3、API的介绍 4.8 wait notify 的正确姿势4.9 Park & Unpark4.10 重新理解线程状态转换4.11 多把锁 4.7 wait notify 1、为什么需要wait 当持有锁的线程因为某种条件不能满足不能执行时&#xff0c;由于其持有…

usb的传输类型

usb的传输类型 usb的四种传输类型: 批量传输同步传输(或等时传输)中断传输控制传输 其中的批量,同步,中断,三种传输中,每完整传输一次数据都称做一个事务(主要的数据传输是靠这三种传输) 事务的具体表现(批量,同步,中断) ​ 上图说说的输入事务是以主机来说的, 主机需要先发…

EMC学习笔记(三)滤波

滤波 1.概述2.滤波器件2.1 电阻2.2 电感2.3 电容2.4 铁氧体磁珠2.5 共模电感 3.滤波电路3.1 滤波电路的形式3.2 滤波电路的布局与布线 4.电容在PCB的EMC设计中的应用4.1 滤波电容的种类4.2 电容自谐振问题4.3 ESR对并联电容幅频特性的影响4.4 ESL对并联电容幅频特性的影响4.5 电…

JVM原理:JVM运行时内存模型(通俗易懂)

目录 前言正文虚拟机栈局部变量表操作数栈动态链接方法返回地址 本地方法栈本地方法存在的意义本地方法的调用 虚拟机堆堆结构Eden区Survivor区域老年代Old区常用参数指令 方法区常量池 运行时常量池方法信息类信息域信息JDK1.7前的方法区JDK1.7时的方法区JDK1.7后的方法区 程序…

Spring-2

DI 依赖注入 所谓依赖注入&#xff0c;是指程序运行过程中&#xff0c;如果需要调用另一个对象协助时&#xff0c;无须在代码中创建被调用者&#xff0c;而是依赖于外部的注入<bean id”” class”” p:属性名称-ref”另外受管 bean 的名称”/> IoC 实际上有 2 种实现 …

探索Python工具库合集:提高开发效率的秘密武器

前言&#x1f680;&#x1f680; 在开发过程中&#xff0c;笔者积累了许多实用的Python工具函数和模块&#xff0c;决定将它们整理成一个工具库集合&#xff0c;并与大家分享。本文将介绍笔者的Python工具库集合的核心功能和用途&#xff0c; 在日常的Python开发中&#xff0c;…

Selenium Python教程第6章:使用页面对象

6. Page Objects 页面对象 6.1 什么是页面对象模型(POM)&#xff1f; 页面对象模型(Page Objects Model, POM )是一组旨在表示一个或多个网页的类, 用1个类来保存1个网页上所有的元素&#xff0c;相似的网页可以重用此类。 1个网站通常有多个页面&#xff0c;可以用多个页面类…

(opencv)图像几何变换——缩放

图像缩放是指将图像的尺寸变小或变大的过程&#xff0c;也就是减少或增加源图像数据的像素个数。图像缩放一定程度上会造成信息的丢失&#xff0c;因此需要考虑适宜的方法进行操作。 下面介绍两种常用的图像缩放方法的原理及实现 1.基于等间隔提取图像缩放 等间隔提取图像缩…

多线程目录

基础概念篇 001线程状态图示_存在,及合理的博客-CSDN博客例如&#xff1a;随着人工智能的不断发展&#xff0c;机器学习这门技术也越来越重要&#xff0c;很多人都开启了学习机器学习&#xff0c;本文就介绍了机器学习的基础内容。提示&#xff1a;以下是本篇文章正文内容&…

机器学习 day16(前向传播算法,Tensorflow的实现代码)

1. 手写数字识别的神经网络模型 为简单起见&#xff0c;仅区分手写0和1&#xff0c;并用8*8的像素矩阵&#xff0c;共有64个像素&#xff08;特征&#xff09;&#xff0c;展开写成向量x&#xff0c;即该神经网络模型的输入特征向量x的维数为64&#xff0c;设该模型有两层隐藏…

一文打通:从字节码指令的角度解读前置后置自增自减(加加++减减--)

文章目录 1.前置了解的知识1.1 栈这种数据结构1.2 局部变量表和操作数栈1.3 三个字节码指令 2.单独使用后置与前置2.1 后置字节码指令2.2 前置字节码指令2.3 总结 3.需要返回值的情况下使用后置与前置3.1 后置字节码指令3.2 前置字节码指令3.3 总结3.4 练习&#x1f340; 练习一…

npm i安装依赖包报错proxy‘ config is set properly. See: ‘npm help config‘

npm i 报错proxy‘ config is set properly. See: ‘npm help config‘ 网上搜了解决方法&#xff1a; https://blog.csdn.net/zz00008888/article/details/127852233 但是执行完还是报错&#xff0c;查代理已经是false了 看到是cnpm镜像&#xff0c;于是用cnpm i 就运行成功…

设计模式篇---原型模式

文章目录 概念Java中的克隆方法实例使用场景 概念 定义&#xff1a;使用原型实例指定待创建对象的类型&#xff0c;并通过复制这个原型来创建新的对象。 原型模式主要有以下几部分组成&#xff1a; Prototype(抽象原型类):具体原型类的接口或者抽象类。 ConcretePrototype(具体…

Mybatis 全系列目录引导(持续更新)

基础篇 001Mybatis常用的网站及工具_存在,及合理的博客-CSDN博客GITHUB。https://blog.csdn.net/qq_26594041/article/details/131098123002Mybatis初始化引入_存在,及合理的博客-CSDN博客自动检测工程中的DataSource创建并注册SqlSessionFactory实例创建并注册SqlSessionTemp…

OpenGL光照之颜色

文章目录 创建一个光照场景 现实世界中有无数种颜色&#xff0c;每一个物体都有它们自己的颜色。我们需要使用&#xff08;有限的&#xff09;数值来模拟真实世界中&#xff08;无限&#xff09;的颜色&#xff0c;所以并不是所有现实世界中的颜色都可以用数值来表示的。然而我…

物联网Lora模块从入门到精通(四)对某些端口的初始化

一、前言 由于程序设计开发具有的不确定性&#xff0c;我们常常需要初始化某些特定的引脚&#xff0c;并读取引脚电平状态或向引脚输出高低电平。 二、代码实现 快速找到端口的初始化语句&#xff1a; 首先&#xff0c;找到board.c文件&#xff0c;在下图的位置&#xff0c;我…

【算法系列专栏介绍】

序言 你只管努力&#xff0c;其他交给时间&#xff0c;时间会证明一切。 文章标记颜色说明&#xff1a; 黄色&#xff1a;重要标题红色&#xff1a;用来标记结论绿色&#xff1a;用来标记一级论点蓝色&#xff1a;用来标记二级论点 决定开一个算法专栏&#xff0c;希望能帮助大…

什么是域控服务器?域控服务器功能?部署域控需要考虑因素?域控组策略功能?

一、什么是域控制服务器&#xff1f; 域控制器&#xff08;Domain Controller&#xff09;是在Windows Server操作系统上运行的一个服务角色&#xff0c;它用于管理和控制一个或多个计算机的安全策略、用户身份验证和授权等任务。域控制器通常是用于企业网络中的主要身份验证和…

性能测试从0到1实战,超详细性能测试计划编写汇总...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、测试背景 首先…