Java笔记02——整形类型与变量

1. 数据类型和变量

变量指的是程序运行时可变的量. 相当于开辟一块内存空间来保存一些数据. 类型则是对变量的种类进行了划分, 不同的类型的变量具有不同的特性.

1.1 整型变量(重点)

基本语法格式
int 变量名 = 初始值;
代码示例:
int num = 10; // 定义一个整型变量
System.out.println(num) ;
注意事项:
1. int 表示变量的类型是一个整型
2. 变量名是变量的标识. 后续都是通过这个名字来使用变量
3. Java 中 = 表示赋值(和数学不一样), 意思是给变量设置一个初始值.
4. 初始化操作是可选的, 但是建议创建变量的时候都显式初始化.
5. 最后不要忘记分号, 否则会编译失败.
6. // 表示注释. 注释作为代码的解释说明部分, 不参与编译运行.
温馨注释:
在 Java 中, 一个 int 变量占 4 个字节. 和操作系统没有直接关系.
什么是字节?
字节是计算机中表示-空间大小-的--基本单位--.
计算机使用二进制表示数据. 我们认为 8 个二进制位(bit) 为一个字节(Byte).
我们平时的计算机为 8GB 内存, 意思是 8G 个字节.
其中 1KB = 1024 Byte, 1MB = 1024 KB, 1GB = 1024 MB.
所以 8GB 相当于 80 多亿个字节.

​ 4 个字节表示的数据范围是 -2^31 -> 2^31-1 , 也就大概是 -21亿 到 +21亿.

使用以下代码查看 Java 中的整型数据范围:

System.out.println(Integer.MAX_VALUE);  // int 的最大值
System.out.println(Integer.MIN_VALUE);  // int 的最小值

在IDEA里运行结果:

img

如果运算的结果超出了 int 的最大范围, 就会出现溢出的情况:

运行代码:

int MAX = Integer.MAX_VALUE;
int MIN = Integer.MIN_VALUE;
System.out.println("MAX = " + MAX);
System.out.println("MIN = " + MIN);
System.out.println("MAX + 1 =" + (MAX + 1) );//这里一定要有括号
System.out.println("MIN + 1 =" + (MIN + 1) );//这里一定要有括号

运行结果:

img

  21亿这样的数字对于当前的大数据时代来说, 是很容易超出的. 针对这种情况, 我们就需要使用更大范围的数据类型来表示了,Java 中提供了 **long 类型**.

1.2 长整型变量

基本语法格式:
long 变量名 = 初始值;
代码示例:
long num = 10L; // 定义一个长整型变量, 初始值写作 10l 也可以(小写的 L, 不是数字1). 
System.out.println(num) ;
注意事项:
1. 基本语法格式和创建 int 变量基本一致, 只是把类型修改成 long
2. 初始化设定的值为 10L , 表示一个长整型的数字. 10l 也可以.
3. 使用 10 初始化也可以, 10 的类型是 int, 10L 的类型是 long, 使用 10 L 或者 10 l 更好一些.
温馨提示:

Java 中 long 类型占 8 个字节. 表示的数据范围 -2^63 -> 2^63-1

运行代码:

使用以下代码查看 Java 中的长整型数据范围

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

运行结果:

img

这个数据范围远超过 int 的表示范围. 足够绝大部分的工程场景使用

1.3 双精度浮点型变量(重点)

基本语法格式
double 变量名 = 初始值;
代码示例:
double num = 1.0;
System.out.println(num);//1.0
double须知:

当你运行下面的代码时,得到的结果可能给你的预期不一样

案例1:

int a = 10;
int b = 20;
System.out.println(a / b);
// 执行结果
0

**原因:**在 Java 中, int 除以 int 的值仍然是 int (会直接舍弃小数部分)。

**解决方法:**如果想得到 0.5, 需要使用 double 类型计算.

double a = 10.0;
double b = 20.0;
System.out.println(a / b);
// 执行结果
0.5

**温馨提示:**也可以只改变其中某个值的 字面量,不同类型混合运算会 整形提升,后面会讲到。

案例2:

double num = 1.1;
System.out.println(num * num)
    
// 执行结果
1.2100000000000002

运行实例:

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
文件上传是Web开发中常见的功能之一,Java中也提供了多种方式来实现文件上传。其中,一种常用的方式是通过Apache的commons-fileupload组件来实现文件上传。 以下是实现文件上传的步骤: 1.在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.3</version> </dependency> ``` 2.在前端页面中添加文件上传表单: ```html <form method="post" enctype="multipart/form-data" action="upload"> <input type="file" name="file"> <input type="submit" value="Upload"> </form> ``` 3.在后台Java代码中处理上传文件: ```java // 创建一个DiskFileItemFactory对象,用于解析上传的文件 DiskFileItemFactory factory = new DiskFileItemFactory(); // 设置缓冲区大小,如果上传的文件大于缓冲区大小,则先将文件保存到临时文件中,再进行处理 factory.setSizeThreshold(1024 * 1024); // 创建一个ServletFileUpload对象,用于解析上传的文件 ServletFileUpload upload = new ServletFileUpload(factory); // 设置上传文件的大小限制,这里设置为10MB upload.setFileSizeMax(10 * 1024 * 1024); // 解析上传的文件,得到一个FileItem的List集合 List<FileItem> items = upload.parseRequest(request); // 遍历FileItem的List集合,处理上传的文件 for (FileItem item : items) { // 判断当前FileItem是否为上传的文件 if (!item.isFormField()) { // 获取上传文件的文件名 String fileName = item.getName(); // 创建一个File对象,用于保存上传的文件 File file = new File("D:/uploads/" + fileName); // 将上传的文件保存到指定的目录中 item.write(file); } } ``` 以上代码中,首先创建了一个DiskFileItemFactory对象,用于解析上传的文件。然后设置了缓冲区大小和上传文件的大小限制。接着创建一个ServletFileUpload对象,用于解析上传的文件。最后遍历FileItem的List集合,判断当前FileItem是否为上传的文件,如果是,则获取文件名,创建一个File对象,将上传的文件保存到指定的目录中。 4.文件上传完成后,可以给用户一个提示信息,例如: ```java response.getWriter().write("File uploaded successfully!"); ``` 以上就是使用Apache的commons-fileupload组件实现文件上传的步骤。需要注意的是,文件上传可能会带来安全隐患,因此在处理上传的文件时,需要进行严格的校验和过滤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值