Java数据类型及其扩展

数据类型

  1. 强类型语言 :要求变量的使用要严格符合规定,所有变量必须先定义后才能使用。
  2. 弱类型语言
  3. 数据类型分为两类
    1. 基本数据类型
    2. 引用数据类型:[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pmEdDeFG-1672821202830)(C:\Users\AS\AppData\Roaming\Typora\typora-user-images\image-20230104135640292.png)]
public class Demo01 {
    public static void main(String[] args) {
        //整数
        int num1 = 100000; //最常用
        byte num2 = 20;
        short num3 = 30;
        long num4 = 30L;//Long类型要在数字后面加上L用以区分

       //小数:浮点数
       float num5 = 50.1F;//Float类型要在数字后面加上F用以区分
       double num6 = 3.1415926535;
       
       
       //字符
        char name = '中';
        //字符串。string不是关键字,类
        //String namea = "中国";
        
        
       //布尔值:是非
       boolean flag = true;
       boolean flag1 = false;


    }
}
  1. 字节

    1. 位(bit):计算机内部数据存储的最小单位,11001100是一个八位二进制数。

    2. 字节(byte):计算机中数据处理的基本单位,习惯用大写的B表示。

    3. 1B=8bit

    4. 字符:计算机中使用的字母,数字,字和符号。

  2. 扩展

    public class Demo02 {
        public static void main(String[] args) {
            //整数扩展 :进制  二进制0b   八进制0   十六进制0x
    
            int i = 10;
            int i2 = 010;
            int i3 = 0x10;
            System.out.println(i);
            System.out.println(i2);
            System.out.println(i3);
            System.out.println("======================================");
    
            //======================================
            //浮点数扩展?银行业务怎么表示?——钱——用BigDecimal 数据工具类
            //======================================
            //float :有限,离散,舍入误差,大约,无限接近
            //double
            //少使用浮点数进行比较
    
    
            float f = 0.1f;
            double d = 1.0/10;
    
            System.out.println(f==d);   //false
    
            float f1 = 231323132313f;
            float f2 = f1 + 1;
    
            System.out.println(f1==f2); //true
    
            System.out.println("======================================");
    
            //字符扩展
    
            char c1 = 'a';
            char c2 = '中';
    
            System.out.println(c1);  //输出:a
    
            System.out.println((int)c1);//强制转换,输出:97
    
            System.out.println(c2);  //输出:中
    
            System.out.println((int)c2);//输出:20013
    
            //所有的字符本质仍是数字
            //编码 Unicode编码表
    
            char c3 = '\u0061';
            System.out.println(c3);//输出:a
    
            //转义字符
            // \t  制表符
            // \n 换行
            System.out.println("Hello\nworld");
    
            System.out.println("======================================");
    
            //对象,从内存分析
            String sa = new String("Hello world");
            String sb = new String("Hello world");
            System.out.println(sa==sb);//false
    
    
            String sc = "Hello world";
            String sd = "Hello world";
            System.out.println(sc==sd);//true
    
    
    
    
            //布尔值扩展
    
            boolean flag = true;
    
    
            if(flag==true){}  // 新手
            if (flag){}      //老手
    
    
    
        }
    }
    
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java 中的集合型是一组针对不同的数据结构实现的接口和实现,用于存储和管理数据元素。它们提供了一种灵活的、高效的方法来存储和管理数据,是 Java 编程中非常重要的一部分。 主要的集合型有: - List:元素有序,可重复,通过索引来访问元素。常见的实现有 ArrayList 和 LinkedList。 - Set:元素无序,不可重复,通常通过迭代器遍历元素。常见的实现有 HashSet 和 TreeSet。 - Map:存储键/值对,键唯一,通过键来访问值。常见的实现有 HashMap 和 TreeMap。 总体来说,集合型具有如下特点: - 提供了一组标准的、统一的接口,便于统一管理和访问数据元素。 - 支持动态扩展和缩小,可以随着数据的增加或减少而调整存储空间。 - 提供了丰富的操作,如插入、删除、查询、排序等,方便编写灵活的代码。 - 高效,使用的是不同的数据结构实现,根据实际需要选择合适的实现。 ### 回答2: 在Java中,集合型主要有List、Set和Map。 List是有序的集合,可以存储重复的元素,常用的实现有ArrayList和LinkedList。ArrayList是基于数组实现的,支持快速随机访问和增删操作较慢;LinkedList是基于双向链表实现的,支持快速增删操作但随机访问较慢。 Set是无序的集合,不允许存储重复的元素,主要实现有HashSet和TreeSet。HashSet是基于哈希表实现的,插入和查询速度快,元素的存储顺序不确定;TreeSet是基于红黑树实现的,元素按照自然顺序或者自定义的比较器进行排序,插入和查询速度较慢。 Map是一种键-值对的映射关系,key和value都可以重复,常用的实现有HashMap和TreeMap。HashMap基于哈希表实现,插入和查询速度快,元素的存储顺序不确定;TreeMap基于红黑树实现,按照key的自然顺序或者自定义的比较器进行排序,插入和查询速度较慢。 此外,Java还提供了其他集合型,如Queue、Deque和SortedSet等,它们在特定场景下有特殊的用途和特点。 总而言之,Java中的集合型提供了丰富的选择,可以根据不同的需求和场景选择合适的集合型,方便进行数据的存储、查找和操作。 ### 回答3: Java中的集合型有ArrayList、LinkedList、HashSet、LinkedHashSet、TreeSet 和HashMap。它们分别属于List、Set和Map接口的实现。 ArrayList是使用数组实现的动态数组,它可以根据需要自动调整大小。它有以下特点:快速访问元素,通过下标获取元素的速度很快,但插入和删除元素相对较慢,需要移动其他元素;允许重复元素;元素的顺序与添加顺序相同。 LinkedList是使用双向链表实现的集合,它有以下特点:插入和删除元素速度较快,不需要移动其他元素;访问元素相对较慢,需要遍历链表;允许重复元素;元素的顺序与添加顺序相同。 HashSet是使用哈希表实现的集合,它有以下特点:插入,删除和查找元素的速度很快;不保证元素的顺序,可以快速确定是否包含某个元素;不允许重复元素;允许存储null值。 LinkedHashSet是使用哈希表和链表实现的集合,它有以下特点:继承自HashSet,具有HashSet的特点;保证元素的顺序与添加顺序相同。 TreeSet是使用红黑树实现的有序集合,它有以下特点:插入,删除和查找元素的速度较快;保证元素的顺序是升序,默认是自然顺序;不允许重复元素。 HashMap是使用哈希表实现的键值对集合,它有以下特点:插入,删除和查找键值对的速度很快;不保证键值对的顺序,可以根据键快速确定值;允许使用null作为键和值;允许重复值,但不允许重复键。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值