【JavaSE】数据类型与变量

news2025/1/12 6:20:09

数据类型与变量

  • 数据类型与变量
    • 1. 字面常量
    • 2. 数据类型
    • 3. 变量
      • 3.1 变量概念
      • 3.2 语法格式
        • 3.3.1 整型变量
        • 3.3.2 长整型变量
        • 3.3.3 短整型变量
        • 3.3.4 字节型变量
      • 3.3 浮点型变量
        • 3.4.1 双精度浮点型
        • 3.4.2 单精度浮点型
      • 3.4 字符型类型
      • 3.5 布尔型变量
      • 3.6 类型转换
        • 3.7.1 自动类型转换(隐式)
        • 3.7.2 强制类型转换(转换)
      • 3.7 类型提升
      • 3.8 字符串变量

数据类型与变量

【本节目标】

  1. 字面常量

  2. 数据类型

  3. 变量

1. 字面常量

在上个文章HelloWorld程序中,System.Out.println("Hello World");语句,不论程序何时运行,输出的都是Hello world,其实"Hello World"就是字符串常量 。

常量即程序运行期间,固定不变的量称为常量,比如:一个礼拜七天,一年12个月等。

public class Demo{
    public static void main(String[] args){
         System.Out.println("hello world!");  //字符串常量
         System.Out.println(100);  //整型常量
         System.Out.println(3.14);  //浮点数常量
         System.Out.println('A');  //字符常量
         System.Out.println(true);  //布尔常量
         System.Out.println(false);  //布尔常量
   }
}

其中:100、3.14、‘A’、true/false都是常量,将其称为字面常量。

字面常量的分类:

  1. 字符串常量:由""括起来的,比如“12345”、“hello”、“你好”。

  2. 整形常量:程序中直接写的数字(注意没有小数点),比如:100、1000

  3. 浮点数常量:程序中直接写的小数,比如:3.14、0.49

  4. 字符常量:由 单引号 括起来的当个字符,比如:‘A’、‘1’

  5. 布尔常量:只有两种true和false

  6. 空常量:null(后面讲)

注意:字符串、整形、浮点型、字符型以及布尔型,在Java中都称为数据类型。

补充

Java中也有类似于C语言中const的关键字呢?

public class HelloWorld {
    /*
    这就是一个块注释
     */

    //快捷键m main psvm 出现提示之后 回车就都能生成一个main方法
    public static void main(String[] args) {
        final int a = 10;//类似于C语言中const的关键字 这个final现在这里展示一下,后期会进行讲解
        //final修饰后的变量就成了常量
        //快捷键sout 出现提示之后 回车即可
        System.out.println("hello world");
    }
}

public class HelloWorld {
    public static void main(String[] args) {
        //数据类型 变量 = 赋值  变量是可以在运行的过程当中修改的量
        final int a = 10;

        a = 20;  //如果经过final修饰的变量就成为了常量,再进行修改就会报错
    }

2. 数据类型

在Java中数据类型主要分为两类:基本数据类型引用数据类型

基本数据类型有四类八种:

  1. 四类:整型、浮点型、字符型以及布尔型

  2. 八种:

数据类型关键字内存占用范围
字节型byte1 字节-128 ~ 127
短整型short2 字节-32768 ~ 32767
整型int4 字节-2^31 ~ 2^31 - 1
长整型long8 字节-2^63 ~ 2^63 - 1
单精度浮点型float4 字节有范围,一般不关注
双精度浮点型double8 字节8字节有范围,一般不关注
字符型char2字节0 ~ 65535
布尔型boolean没有明确规定true 和 false

image-20221031183857247

注意:

  • 不论是在16位系统还是32位系统,int都占用4个字节,long都占8个字节
  • 整形和浮点型都是带有符号的
  • 整型默认为int型,浮点型默认为double
  • 字符串属于引用类型,该中类型后序介绍。

什么是字节?

字节是计算机中表示空间大小的基本单位.

计算机使用二进制表示数据. 我们认为 8 个二进制位(bit) 为一个字节(Byte).

我们平时的计算机为 8GB 内存, 意思是 8G 个字节.

其中 1KB = 1024 Byte, 1MB = 1024 KB, 1GB = 1024 MB.

所以 8GB 相当于 80 多亿个字节.

3. 变量

3.1 变量概念

在程序中,除了有始终不变的常量外,有些内容可能会经常改变,比如:人的年龄、身高、成绩分数、数学函数的计算结果等,对于这些经常改变的内容,在Java程序中,称为变量。而数据类型就是用来定义不同种类变量的。

3.2 语法格式

定义变量的语法格式为:

数据类型 变量名 = 初始值;

代码示例

如何定义变量?

public class HelloWorld {
    public static void main(String[] args) {
        //数据类型 变量 = 赋值  变量是可以在运行的过程当中修改的量
        int a = 10;

    }
int a = 10;   // 定义整形变量a,a是变量名也称为标识符,该变量中放置的值为10
double d = 3.14;
char c = 'A';
boolean b = true;
System.Out.println(a);
System.Out.println(d);
System.Out.println(c);
System.Out.println(b);
a = 100;  // a是变量,a中的值是可以修改的,注意:= 在java中表示赋值,即将100交给a,a中保存的值就是100
System.Out.println(a);
// 注意:在一行可以定义多个相同类型的变量
int a1 = 10, a2 = 20, a3 = 30;
System.Out.println(a1);
System.Out.println(a2);
System.Out.println(a3);

3.3.1 整型变量

整形变量的取值范围

在Java中没有所谓的无符号和有符号这样的概念

int 占用4个字节,是32个bit位

32个bit位当中最高位为符号位,31个比特位为数值位

image-20221031190605322

最大值为

0 1111111 11111111 11111111 11111111

最小值为

1 1111111 11111111 11111111 11111111

所以取值范围是-2^31 ~ 2^31-1

当然也可以通过代码求得int的取值范围

    public static void main(String[] args) {
        int a = 10;
        System.out.println(a); //打印10
        
        System.out.println(Integer.MAX_VALUE);
        System.out.println(Integer.MIN_VALUE);
    }
}
//-------------------
//编译器运行结果为
//10
//2147483647
//-2147483648

image-20221031201451525

Integer就是int的plus版本,比int强大,至于多强大,后续介绍。

这里只是我们通过Integer访问最大值最小值

2147483647就是int所能存储的最大值,如果一个数比int最大值还要大,那么就存不进去了。

而我们就需要一个更大的数据类型进行存储。

这也就是涉及到了为什么有这么多种数据类型?

原因:在合适的场景下使用合适的数据类型。

也就是long长整型。

整型变量的定义方式

// 方式一:在定义时给出初始值
int a = 10;
System.Out.println(a);
// 方式二:在定义时没有给初始值,但使用前必须设置初值
int b; b = 10;
System.Out.println(b);
// 使用方式二定义后,在使用前如果没有赋值,则编译期间会报错
int c;
System.Out.println(c);
c = 100;
// int型变量所能表示的范围:
System.Out.println(Integer.MIN_VALUE);
System.Out.println(Integer.MAX_VALUE);
// 注意:在定义int性变量时,所赋值不能超过int的范围
int d = 12345678901234;  // 编译时报错,初值超过了int的范围

注意事项:

  1. int不论在何种系统下都是4个字节

  2. 推荐使用方式一定义,如果没有合适的初始值,可以设置为0

  3. 在给变量设置初始值时,值不能超过int的表示范围,否则会导致溢出

  4. 变量在使用之前必须要赋初值,否则编译报错

  5. int的包装类型为 Integer

3.3.2 长整型变量

长整形变量的取值范围

long是8个字节,就是64个比特位,一位为符号位,其它63位为数值位。

所以long的取值范围就是-2^63 ~ 2^63-1

代码求范围

public class HelloWorld {
    public static void main(String[] args) {
        long a = 10;
        System.out.println(a);

        System.out.println(Long.MAX_VALUE);
        System.out.println(Long.MIN_VALUE);
    }
}
//-------------
//编译器运行结果为
//10
//9223372036854775807
//-9223372036854775808

我们可以先把Long理解为long的plus版本

关于包装类我们后期会讲

长整型类型的定义

int a = 10;
long b = 10;   // long定义的长整型变量
long c = 10L; // 为了区分int和long类型,一般建议:long类型变量的初始值之后加L或者l
long d = 10l; // 一般更加以加大写L,因为小写l与1不好区分
// long型变量所能表示的范围:这个数据范围远超过 int 的表示范围. 足够绝大部分的工程场景使用. 
System.Out.println(Long.MIN_VALUE);
System.Out.println(Long.MAX_VALUE);

注意事项:

  1. 长整型变量的初始值后加L或者l,推荐加L

  2. 长整型不论在那个系统下都占8个字节

  3. 长整型的表示范围为:-2^63 ~ 2^63-1

  4. long的包装类型为Long

    public static void main(String[] args) {
        long a = 10L;
        System.out.println(a);
    }

长整型变量的初始值后一般加L

初始值10后面加L表示这是一个long类型的10

不加表示这是一个整型10

10是一个整型的字面值常量

不推荐加小写l,因为在某些情况下会误认为1。

3.3.3 短整型变量

短整形变量的取值范围

short占用2个字节,是16个比特位,其中一位是符号位,剩余15个比特位就是数值位。

所以short的取值范围是-2^15 ~ 2^15-1

代码求范围

public static void main(String[] args) {
        //2个字节
        short sh = 10;
        System.out.println(sh);

        System.out.println(Short.MAX_VALUE);
        System.out.println(Short.MIN_VALUE);

    }
//-------------
//编译器运行结果为
//10
//32767
//-32768

短整型变量定义

short a = 10;
System.Out.println(a);
// short型变量所能表示的范围:
System.Out.println(Short.MIN_VALUE);
System.Out.println(Short.MAX_VALUE);

注意事项:

  1. short在任何系统下都占2个字节

  2. short的表示范围为:-32768 ~ 32767

  3. 使用时注意不要超过范围(一般使用比较少)

  4. short的包装类型为Short

Java的安全性

image-20221031212628611

如果给定的值超过了所能存储的最大值,那么就直接给报错了。

如果在C语言中只是会给予警告,不会报错。

C语言虽然存在问题,但是是一门经典的语言。

有《C缺陷与陷阱》但是没有《其他语言缺陷与陷阱》。

说明C语言坑实在是太多了[doge],值得写一本书。

但是并不是说C语言不好。

Java语言的优点。

可移植性:一次编译,到处运行

安全性

3.3.4 字节型变量

字节形变量的取值范围

byte类型占用一个字节,一个字节8个bit位,一个bit位是符号位,7个bit位是数值位

那么byte的取值范围是-2^7 - 2^7-1**(-128—127)**

-128—127这个范围是需要准确记忆的。

代码求取值范围

    public static void main(String[] args) {
        //1个字节 8个bit位
        byte a = 10;
        System.out.println(a);
        System.out.println(Byte.MAX_VALUE);
        System.out.println(Byte.MIN_VALUE);
    }
//-----------
//编译器运行结果为
//10
//127
//-128

这个包装类中只有int的包装类是Integer

其它类型的包装类都是类型首字母大写。

byte b = 10;
System.Out.println(b);
// byte型变量所能表示的范围:
System.Out.println(Byte.MIN_VALUE);
System.Out.println(Byte.MAX_VALUE);

注意事项:

  1. byte在任何系统下都占1个字节

  2. byte的范围是:-128 ~ 127

  3. 字节的包装类型为Byte

思考:byte、short、int、long都可以定义整形变量,为什么要给出4中不同类型呢?

这就好比买衣服时的尺码:

我们应该穿合适的衣服,数据应该存放到合适的类型中。

在Java当中不能存储超过取值范围的值,如果超过的话就会报错。

3.3 浮点型变量

3.4.1 双精度浮点型

双精度浮点数的取值范围

public static void main(String[] args) {
double d = 12.5;        System.out.println(Double.MAX_VALUE);System.out.println(Double.MIN_VALUE);
}
//-------------
//编译器运行结果为
//12.5
//1.7976931348623157E308
//4.9E-324

我们一般不讨论小数的最大值和最小值。所以这个不需要记忆。

在Java语言当中浮点数用println打印后面不会自动补0。

一段代码

    public static void main(String[] args) {
        int a = 1;
        int b = 2;
        System.out.println(a/b);
    }
//---------
//编译器运行结果为
//0

因为a和b都是整型,所以运算后的结果也是整型。

Java **, int** 除以 int 的值仍然是 int(会直接舍弃小数部分)。如果想得到 0.5, 需要使用 double 类型计算。

如果想让最后的结果是0.5,那么至少a和b中有一个是小数。

    public static void main(String[] args) {
        int a = 1;
        int b = 2;
        System.out.println(1.0*a/b);
    }

或者

double a = 1.0;
double b = 2.0;
System.out.println(a / b);   // 输出0.5

如果想要在Java当中进行小数位的保留的话,代码如下

double d = 12.500;
System.out.println(d);  //这里不会输出12.500,会输出12.5
        System.out.printf("%.2f",d);

在Java当中很少用到printf,一般用println

补充

块注释的快捷键是`ctrl+shift+/`

块注释和取消块注释的快捷键相同。

行注释的快捷键是`ctrl+/`

行注释和取消行注释的快捷键相同。
public static void main(String[] args) {
        double d = 1.1;
        System.out.println(d*d);
    }
//------------
//编译器运行结果为
//1.2100000000000002

为什么不是1.21呢?

因为小数其实没有精确的,只能说精确到某一位上。

注意事项:

  1. double在任何系统下都占8个字节

  2. 浮点数与整数在内存中的存储方式不同,不能单纯使用 的形式来计算

  3. double的包装类型为Double

  4. double 类型的内存布局遵守 IEEE 754 标准(和C语言一样), 尝试使用有限的内存空间表示可能无限的小数, 势必会存在一定的精度误差,因此浮点数是个近似值,并不是精确值。

3.4.2 单精度浮点型

image-20221101195707135

这里编译器报错,因为小数默认是double类型。

double是8个字节,float是4个字节,当把一个8字节的数据存储到4字节当中的时候,Java会直接报错。

在Java编译器当中等号右边的数据类型的大小比等号左边的数据类型大小更大的时候,必须进行强制类型转换,使得两边等号一致。

这里怎么解决呢?

进行强制类型转换。

public static void main(String[] args) {
	float f = 12.5f;
}
float num = 1.0f;    // 写作 1.0F 也可以
System.out.println(num);

flfloat 类型在 Java 中占四个字节, 同样遵守 IEEE 754 标准. 由于表示的数据精度范围较小, 一般在工程上用到浮点数都优先考虑 double, 不太推荐使用 flfloat. flfloat的包装类型为Float。

实际上八种基本数据类型中,只有int的包装类是Integer,剩下七种数据类型的包装类都是首字母大写。

补充

包装类型是什么?

是基本数据类型对应的类类型——专业术语

是基本数据类型的加大版本,他具备的功能比较多,它可以提供很多的方法让我们使用,具体的后面会专门讲,现在我们只需要知道,每个基本的数据类型对应的包装类是什么就好了,具体用的时候呢,我们就知道了。

3.4 字符型类型

字符类型的使用

public static void main(String[] args) {
char ch1 = 'a';
System.out.println(ch1);
char ch2 = '美';
System.out.println(ch2);
}
//----------
//编译器运行结果为
//a
//美

一个汉字两个字节,而我们的字符类型也是两个字节,所以能够进行存储。

public static void main(String[] args) {
char ch = 97;
System.out.println(ch);
}
//-------------
//编译器运行结果为
//a

Java当中的字符类型是专门用来存放字符的。

即使放一个数值在char字符类型中,也只会输出对应的字符。

C语言学习过程中我们的字符类型对应的是ascii码字符集——总共256个,因为总共8个bit位其实全部是数值位

Java字符类型占用2个字节,是16个bit位,不能赋值负数

2^16=65536

而且不能存储负数,如果存储会直接报错。

Java中所用的字符集是Unicode

‘a’——97

‘A’——65

字符集和字符编码是两个概念,自己下来了解下。

char c1 = 'A';    // 大写字母
char c2 = '1';    // 数字字符
System.out.println(c1);
System.out.println(c2);
// 注意:java中的字符可以存放整形
char c3 = '帅';
System.out.println(c3);

注意事项:

  1. Java 中使用 单引号 + 单个字母 的形式表示字符字面值.

  2. 计算机中的字符本质上是一个整数. 在 C 语言中使用 ASCII 表示字符, 而 Java 中使用 Unicode 表示字符. 因此一个字符占用两个字节, 表示的字符种类更多, 包括中文

  3. char的包装类型为Character

char ch = '呵';
System.out.println(ch);

执行 javac 的时候可能出现以下错误:

Test.java:3: 错误: 未结束的字符文字
       char ch = '鍛?';
                 ^

此时我们在执行 javac 时加上 -encoding UTF-8 选项即可

javac -encoding UTF-8 Test.java

3.5 布尔型变量

布尔类型常用来表示真假,在现实生活中也是经常出现的,比如:听说xxx同学买彩票中了一个亿…,听到后估计大部分人第一反应就是:我x,真的假的?

代码的使用

public static void main(String[] args) {
boolean ch = true;
System.out.println(ch);
boolean ch2 = false;
System.out.println(ch2);
}
//------------
//编译器运行结果为
//true
//false

注意事项:

  1. boolean 类型的变量只有两种取值, true 表示真, false 表示假.

  2. Java 的 boolean 类型和 int 不能相互转换, 不存在 1 表示 true, 0 表示 false 这样的用法

  3. Java虚拟机规范中,并没有明确规定boolean占几个字节,也没有专门用来处理boolean的字节码指令,在Oracle公司的虚拟机实现中,boolean占1个字节,但是我们一般都是把它当作是以没有规范为主。

  4. boolean的包装类型为Boolean。

在C语言当中0是假,非0是真,而Java当中真只有一个就是true,假只有一个就是false

果给boolean类型赋值1,编译器认为赋值了整数1,会报错。

image-20221102103159469

强制类型转换也不行,因为两个种类都不同。

image-20221102103331935

在JVM当中并没有明确规定true 和false的大小。

boolean value = true;
System.out.println(value + 1);
// 代码编译会出现如下错误
Test.java:4: 错误: 二元运算符 '+' 的操作数类型错误
        System.out.println(value + 1);
                                 ^
  第一个类型:  boolean
  第二个类型: int
1 个错误

3.6 类型转换

Java 作为一个强类型编程语言, 当不同类型之间的变量相互赋值的时候, 会有教严格的校验.

int a = 10;
long b = 100L; b = a;   // 可以通过编译
a = b;   // 编译失败

在Java中,当参与运算数据类型不一致时,就会进行类型转换。Java中类型转换主要分为两类:自动类型转换(隐 式) 和 强制类型转换(显式)

3.7.1 自动类型转换(隐式)

自动类型转换即:代码不需要经过任何处理,在代码编译时,编译器会自动进行处理。特点:数据范围小的转为数据范围大的时会自动进行

System.Out.println(1024);   // 整型默认情况下是int
System.Out.println(3.14);   // 浮点型默认情况下是double
int a = 100;
long b = 10L; 
b = a;   
// a和b都是整形,a的范围小,b的范围大,当将a赋值给b时,编译器会自动将a提升为long类型,然后赋值
a = b;   
// 编译报错,long的范围比int范围大,会有数据丢失,不安全
float f = 3.14F;
double d = 5.12; 
d = f; // 编译器会将f转换为double,然后进行赋值
f = d; // double表示数据范围大,直接将float交给double会有数据丢失,不安全
byte b1 = 100;  // 编译通过,100没有超过byte的范围,编译器隐式将100转换为byte
byte b2 = 257;  // 编译失败,257超过了byte的数据范围,有数据丢失

3.7.2 强制类型转换(转换)

强制类型转换:当进行操作时,代码需要经过一定的格式处理,不能自动完成。特点:数据范围大的到数据范围小的。

代码示例

int a = 10;
long b = 100L; b = a;   // 可以通过编译
a = b;   // 编译失败

当8个字节的数据存放到4个字节大小的空间当中,势必会丢掉4个字节。所以我们的Java编译器会报错。

如果想要不报错,使用强制类型转换

public static void main(String[] args) {
    int a = 10;
    long b = 20L;
    a = (int)b;
}

但是强制类型转换不一定安全,有一定的风险:有可能丢失掉部分数据,所以需要自己判断是否会丢失数据,再进行强制类型转换。

int a = 10;
long b = 100L; 
b = a;  // int-->long,数据范围由小到大,隐式转换
a = (int)b;  // long-->int, 数据范围由大到小,需要强转,否则编译失败

float f = 3.14F;
double d = 5.12; 
d = f;  // float-->double,数据范围由小到大,隐式转换
f = (float)d;  // double-->float, 数据范围由大到小,需要强转,否则编译失败

a = d;  // 报错,类型不兼容
a = (int)d;  // int没有double表示的数据范围大,需要强转,小数点之后全部丢弃

int g = 10;
float h = 0.1f;
g = h ;  //报错,虽然都是四个字节吗,但是类型不匹配,float表示的精度比int表示的更高。,需要强制类型转换,小数点之后全部丢弃。 

byte b1 = 100;  // 100默认为int,没有超过byte范围,隐式转换
byte b2 = (byte)257;  // 257默认为int,超过byte范围,需要显示转换,否则报错

boolean flag = true; 
a = flag;   // 编译失败:类型不兼容
flag = a;   // 编译失败:类型不兼容

注意事项:

  1. 不同数字类型的变量之间赋值, 表示范围更小的类型能隐式转换成范围较大的类型

  2. 如果需要把范围大的类型赋值给范围小的, 需要强制类型转换, 但是可能精度丢失

  3. 将一个字面值常量进行赋值的时候, Java 会自动针对数字范围进行检查

  4. 强制类型转换不一定能成功,不相干的类型不能互相转换

3.7 类型提升

不同类型的数据之间相互运算时,数据类型小的会被提升到数据类型大的。

1. int与long之间:int会被提升为long

int a = 10;
long b = 20;
int c = a + b;  
// 编译出错: a + b==》int + long--> long + long 赋值给int时8个字节的数据存储到4个字节的空间中可能会丢失数据,如果想要赋值给int类型需要强制类型转换。
//c = (int)(a+b);

long d = a + b;  
// 编译成功:a + b==>int + long--->long + long 赋值给long  

2. byte与byte的运算

byte a = 10;
byte b = 20;
byte c = a + b;
System.out.println(c);
// 编译报错
Test.java:5: 错误: 不兼容的类型: 从int转换到byte可能会有损失
                byte c = a + b;
                           ^

结论: byte 和 byte 都是相同类型, 但是出现编译报错. 原因是, 虽然 a 和 b 都是 byte, 但是计算 a + b 会先将 a和 b 都提升成 int, 再进行计算, 得到的结果也是 int, 这是赋给 c, 就会出现上述错误.

由于计算机的 CPU 通常是按照 4 个字节为单位从内存中读写数据. 为了硬件上实现方便, 诸如 byte 和 short这种低于 4 个字节的类型, 会先提升成 int, 再参与计算.

正确的写法:

byte a = 10;
byte b = 20;
byte c = (byte)(a + b);
System.out.println(c);

补充

byte b = 20;
//这里20默认为int类型,赋值给byte类型不会有问题吗?

编译器会帮我们检查,如果数值的范围是在自己表示的范围内,就不会报错。

入宫超过范围才会报错。

【类型提升小结:】

  1. 不同类型的数据混合运算, 范围小的会提升成范围大的.

  2. 对于 short, byte 这种比 4 个字节小的类型, 会先提升成 4 个字节的 int , 再运算.

3.8 字符串变量

在C语言当中虽然有字符串,但是没有字符串类型。

char* p = "hello";
//这里的p只是一个char* 类型的指针变量

在Java当中我们有了一种全新的类型:String

代码使用

public static void main(String[] args) {
    String str = "hello";
    System.out.println(str);
}
//-----------
//编译器运行结果为
//hello

这里的str是局部变量,此时他们依然是存放在栈上的。

补充

在Java当中没有指针这个说法

int a = 10;

如果想要获取a的地址,Java是做不到的。

在Java里面没有所谓的字符串以‘\0’截止

字符串的拼接

在字符串当中,如果两个字符串进行相加,那么它的意思就是拼接的意思

代码示例

public static void main(String[] args) {
    String str1 = "hello";
    String str2 = "world";
    System.out.println(str1+str2);
}
//---------------
//编译器运行结果为
//helloworld

在有些情况下,需要将字符串和整形数字之间进行转换:

  1. int 转成 String
public static void main(String[] args) {
    int a = 10;
    int b = 20;
    System.out.println("a = "+a);
    System.out.println("b = "+b);
}
//----------
//编译器运行结果为
//a = 10
//b = 20

当字符串拼接任何数据类型的时候,数据类型是字符串类型。

public static void main(String[] args) {
    int a = 10;
    int b = 20;

    System.out.println("a + b = "+a+b);
    System.out.println("a + b = "+(a+b));
    System.out.println(a+b+"是a + b的值 ");
}
//------------
//编译器运行结果为
//a + b = 1020
//a + b = 30
//30是a + b的值 

运算是从左向右进行。

String不是包装类

包装类是基本数据类型对应的类类型

包装类是引用数据类型当中的一种。

数据类型严格上分为两类,1基本数据类型:8种
2引用数据类型:String  Byte 数组 接口等
不过Byte是包装类,String不是包装类,包装类是引用数据类型当中的一种。

int转成String

将一个整数变为字符串

方法一

public static void main(String[] args) {
    int a = 12345;
    String str = String.valueOf(a);
    System.out.println(str);

    float f = 12.5f;
    String ret = String.valueOf(f);
    System.out.println(ret);
}
//-----------
//编译器运行结果为
//12345
//12.5

方法二

方法二有点投机取巧的行为。

public static void main(String[] args) {
    int a = 12345;
    String aa = a+"";
    System.out.println("----->"+aa);
}
//----------
//编译器运行结果为
//12345
//----->12345
  1. String 转成 int
public static void main(String[] args) {
    String str = "123456";
    int a = Integer.valueOf(str);
    System.out.println(a+1);
}
//-----------
//编译器运行结果为
//123457

补充

有时候出现

String str = "100";
int num = Integer.parseInt(str);

Integer.parseIntInteger.valueOf

本质上是相同的。

  1. 触类旁通
public static void main(String[] args) {
    String str = "12.5";
    double d = Double.valueOf(str);
    System.out.println(d);
}
//----------
//编译器运行结果为
//12.5
public static void main(String[] args) {
    String str = "12.5f";
    float f = Float.valueOf(str);
    System.out.println(f);
}
//-----------
//编译器运行结果为
//12.5

本节对只是对字符串进行简单的介绍,大家能够正常使用即可,后序会详细给大家介绍。

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

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

相关文章

TensorFlow 实战案例: ResNeXt 交通标志图像多分类,附Tensorflow完整代码

各位同学好,今天和大家分享一下如何使用 Tensorflow 构建 ResNeXt 神经网络模型,通过 案例实战 ResNeXt 的训练以及预测过程。每个小节的末尾有网络、训练、预测的完整代码。 ResNeXt 是 ResNet 的改进版,在 bottleneck卷积块 结构上进行了较…

阿里高级技术专家方法论:如何写复杂业务代码?

阿里妹导读:张建飞是阿里巴巴高级技术专家,一直在致力于应用架构和代码复杂度的治理。最近,他在看零售通商品域的代码。面对零售通如此复杂的业务场景,如何在架构和代码层面进行应对,是一个新课题。结合实际的业务场景…

ECM工业能耗管理云平台

在我国的能源消耗中,工业企业是能源消耗的主要群体,能源消耗量占全国能源消耗总量的70%左右,传统方式进行各类工厂能耗的计量,造成能耗数据不完整、不准确、不全面,因而无法进行能耗分析与诊断,造成普遍在各…

DFS初入门

目录 一、前言 二、搜索与暴力法 1、概念 2、搜索的基本思路 3、BFS:一群老鼠走迷宫 4、DFS:一只老鼠走迷宫 三、DFS 1、DFS访问示例 2、DFS的常见操作 3、DFS基础:递归和记忆化搜索 4、DFS的代码框架(大量编码后回头体…

一个真正的鳗,他清楚自己每天都要刷《剑指offer》(第九天)

跟着博主一起刷题 这里使用的是题库: https://leetcode.cn/problem-list/xb9nqhhg/?page1 目录剑指 Offer 57 - II. 和为s的连续正数序列剑指 Offer 59 - I. 滑动窗口的最大值剑指 Offer 60. n个骰子的点数剑指 Offer 57 - II. 和为s的连续正数序列 剑指 Offer 57 …

文旅元宇宙热潮来袭,天下秀用“科技之钥”解锁三大价值

让未来照进现实,让现实走进虚拟,元宇宙正成为通往下个时代的船票。2018年上映的电影《头号玩家》,让大部分人首次感触到元宇宙里的沉浸式体验——男主角带上VR头盔后,瞬间就能进入另一个极其逼真的虚拟世界。随着VR、AR、区块链、…

系统回顾MyBatis体验这一优秀的持久层框架

文章目录1.MyBatis2.Mapper代理3.MyBatis配置升级4.配置文件CRUD5.多条件查询6.多条件动态查询7.单条件动态条件查询8.添加数据并主键返回9.更新数据10.删除数据11.参数传递12.注解开发1.MyBatis MyBatis基本上取消了所有的JDBC硬编码,对于单独使用这样的ORM框架&a…

1585_AURIX_TC275_SMU的部分内核寄存器

全部学习汇总: GreyZhang/g_TC275: happy hacking for TC275! (github.com) 继续看SMU的资料,这次看一部分SMU的内核相关寄存器。这一次整理的内容比较少,而且优点断篇,因此按照序号来分没有保持10页的对齐。 调试相关的寄存器不…

详解外网访问内网DDNS作用 及ddns解析软件使用方法

导语:随着互联网的成熟,家庭宽带的提速,大家对外网访问家庭内网电脑,监控,服务器,存储NAS等设备的需求倍增。目前外网访问内网可以用DDNS动态域名解析的方式,以下本文就来介绍一下原理和实现工具…

ELK日志(3)

EFK日志收集 Elasticsearch: 数据库,存储数据 javalogstash: 日志收集,过滤数据 javakibana: 分析,过滤,展示 javafilebeat: 收集日志,传输到ES或logstash go redis:缓冲数据,等待logstash取数据…

高并发多级缓存架构解决方案 OpenResty、canal搭建及使用流程

高并发多级缓存架构解决方案1、缓存的常规使用方式2、请求流程拆分1、搭建tomcat集群2、搭建OpenRestyOpenResty的目录结构nginx的配置文件lua脚本的执行流程http请求反向代理到tomcat服务器3、OpenResty、Redis的单点故障问题4、防止缓存穿透java中通过redisson实现布隆过滤器…

Mac 下配置 go语言环境

Mac 下配置 go语言环境两种方法安装Go通过Homebrew安装(不太推荐)通过官网安装 (推荐)方法一安装Homebrew通过Homebrew安装Go方法二 通过官网进行安装配置go环境配置go环境国内镜像Vscode环境配置Helloworld.go两种方法安装Go 通…

LabVIEW中的VI脚本

LabVIEW中的VI脚本用户可使用VI脚本选板上的VI、函数和相关的属性、方法,通过程序创建、编辑和运行VI。通过VI脚本,可减少重复的VI编辑所需的时间,例如:创建若干类似VI对齐和分布控件显示或隐藏控件标签连接程序框图对象注: 必须先…

【13】Docker_DockerFile | 关键字

目录 1、DockerFile的定义 2、DockerFile内容基本知识 3、Docker执行DockerFile的大致流程 4、DockerFile的关键字 5、举例: 1、DockerFile的定义 Dockerfile是用来构建Docker镜像的文本文件,是由一条条构建镜像所需的指令和参数构成的脚本。 2、Do…

[前端笔记——HTML介绍] 2.开始学习HTML

[前端笔记——HTML介绍] 2.开始学习HTML1什么是HTML?2剖析一个HTML元素3块级元素和内联元素4空元素5属性6为一个元素添加属性7布尔属性8省略包围属性值的引号9单引号或双引号?10剖析HTML文档11实体引用:在 HTML 中包含特殊字符1什么是HTML? …

LeetCode 17. 电话号码的字母组合

🌈🌈😄😄 欢迎来到茶色岛独家岛屿,本期将为大家揭晓LeetCode 17. 电话号码的字母组合,做好准备了么,那么开始吧。 🌲🌲🐴🐴 一、题目名称 17.…

文件操作中的IO流——字节流与字符流

一,IO流1.什么是IO流IO流是存取和读取数据的解决方案2.IO流的作用IO流用于读写数据,这些数据包括本地文件和网络上的一些数据;比如读写本地文件的时候需要用到文件读写的IO流,读写网络上的数据时需要通过Socket套接字来调用数据流…

机器学习:公式推导与代码实现-监督学习单模型

线性回归 线性回归(linear regression)是线性模型的一种典型方法。 回归分析不再局限于线性回归这一具体模型和算法,更包含了广泛的由自变量到因变量的机器学习建模思想。 原理推导 线性回归学习的关键问题在于确定参数w和b,使得拟合输出y与真实输出yi尽可能接近 为了求…

PowerDesigner16.5配置安装与使用

PowerDesigner16.5百度云下载链接 链接:https://pan.baidu.com/s/1b9XUqxVZ8gTqk_9grptcAQ?pwd3pl7 提取码:3pl7 一:软件安装 1.下载安装包(包含安装文件、汉化包、注册文件) 2.下载后文件内容如下 3.进入安装文件中…

5. 统计学基础1:平均值...四分位数、方差、标准差(均方差)、标准误(标准误差、均方根误差)、 标准分

文章目录1. 平均值、中位数、众数、极差、四分位数(即下、中、上四份位数)2. 方差(Var、D(X) 、σ^2^)、标准差【也叫均方差】(SD 、σ)3. 标准误【也叫标准误差、均方根误差】(SE)4…