数据类型与变量
- 数据类型与变量
- 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. 字面常量
在上个文章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都是常量,将其称为字面常量。
字面常量的分类:
-
字符串常量:由""括起来的,比如“12345”、“hello”、“你好”。
-
整形常量:程序中直接写的数字(注意没有小数点),比如:100、1000
-
浮点数常量:程序中直接写的小数,比如:3.14、0.49
-
字符常量:由 单引号 括起来的当个字符,比如:‘A’、‘1’
-
布尔常量:只有两种true和false
-
空常量: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中数据类型主要分为两类:基本数据类型和引用数据类型。
基本数据类型有四类八种:
-
四类:整型、浮点型、字符型以及布尔型
-
八种:
数据类型 | 关键字 | 内存占用 | 范围 |
---|---|---|---|
字节型 | byte | 1 字节 | -128 ~ 127 |
短整型 | short | 2 字节 | -32768 ~ 32767 |
整型 | int | 4 字节 | -2^31 ~ 2^31 - 1 |
长整型 | long | 8 字节 | -2^63 ~ 2^63 - 1 |
单精度浮点型 | float | 4 字节 | 有范围,一般不关注 |
双精度浮点型 | double | 8 字节8字节 | 有范围,一般不关注 |
字符型 | char | 2字节 | 0 ~ 65535 |
布尔型 | boolean | 没有明确规定 | true 和 false |
注意:
- 不论是在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个比特位为数值位
最大值为
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
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的范围
注意事项:
-
int不论在何种系统下都是4个字节
-
推荐使用方式一定义,如果没有合适的初始值,可以设置为0
-
在给变量设置初始值时,值不能超过int的表示范围,否则会导致溢出
-
变量在使用之前必须要赋初值,否则编译报错
-
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);
注意事项:
-
长整型变量的初始值后加L或者l,推荐加L
-
长整型不论在那个系统下都占8个字节
-
长整型的表示范围为:
-2^63 ~ 2^63-1
-
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);
注意事项:
-
short在任何系统下都占2个字节
-
short的表示范围为:-32768 ~ 32767
-
使用时注意不要超过范围(一般使用比较少)
-
short的包装类型为Short
Java的安全性
如果给定的值超过了所能存储的最大值,那么就直接给报错了。
如果在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);
注意事项:
-
byte在任何系统下都占1个字节
-
byte的范围是:-128 ~ 127
-
字节的包装类型为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呢?
因为小数其实没有精确的,只能说精确到某一位上。
注意事项:
-
double在任何系统下都占8个字节
-
浮点数与整数在内存中的存储方式不同,不能单纯使用 的形式来计算
-
double的包装类型为Double
-
double 类型的内存布局遵守 IEEE 754 标准(和C语言一样), 尝试使用有限的内存空间表示可能无限的小数, 势必会存在一定的精度误差,因此浮点数是个近似值,并不是精确值。
3.4.2 单精度浮点型
这里编译器报错,因为小数默认是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);
注意事项:
-
Java 中使用 单引号 + 单个字母 的形式表示字符字面值.
-
计算机中的字符本质上是一个整数. 在 C 语言中使用 ASCII 表示字符, 而 Java 中使用 Unicode 表示字符. 因此一个字符占用两个字节, 表示的字符种类更多, 包括中文
-
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
注意事项:
-
boolean 类型的变量只有两种取值, true 表示真, false 表示假.
-
Java 的 boolean 类型和 int 不能相互转换, 不存在 1 表示 true, 0 表示 false 这样的用法
-
Java虚拟机规范中,并没有明确规定boolean占几个字节,也没有专门用来处理boolean的字节码指令,在Oracle公司的虚拟机实现中,boolean占1个字节,但是我们一般都是把它当作是以没有规范为主。
-
boolean的包装类型为Boolean。
在C语言当中0是假,非0是真,而Java当中真只有一个就是true,假只有一个就是false
果给boolean类型赋值1,编译器认为赋值了整数1,会报错。
强制类型转换也不行,因为两个种类都不同。
在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; // 编译失败:类型不兼容
注意事项:
-
不同数字类型的变量之间赋值, 表示范围更小的类型能隐式转换成范围较大的类型
-
如果需要把范围大的类型赋值给范围小的, 需要强制类型转换, 但是可能精度丢失
-
将一个字面值常量进行赋值的时候, Java 会自动针对数字范围进行检查
-
强制类型转换不一定能成功,不相干的类型不能互相转换
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类型不会有问题吗?
编译器会帮我们检查,如果数值的范围是在自己表示的范围内,就不会报错。
入宫超过范围才会报错。
【类型提升小结:】
-
不同类型的数据混合运算, 范围小的会提升成范围大的.
-
对于 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
在有些情况下,需要将字符串和整形数字之间进行转换:
- 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
- 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.parseInt
和Integer.valueOf
本质上是相同的。
- 触类旁通
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
本节对只是对字符串进行简单的介绍,大家能够正常使用即可,后序会详细给大家介绍。