一、JAVA中两大类型

  • 基本类型(byte、short、int->(Integer)、long、float、double)
  • 类 类型
  • 两者优缺点:使用基本类型效率高,但是类类型里面可以有一些属性、方法

二、基本类型与类类型的相互转化

  • 例如:

    int 与Integer类相互转化

    • public int intValue() Integer 转化成int
    • public static Integer valueOf(String s)throwsNumberFormatExcepton

      int转化成Integer
  • 其他类型与之相似

三、int与Integer之间的区别

  • 代码验证1:
    int i1=1;
    int i2=2;
    System.out.println(i1==i2);//结果为true
  • 代码验证2:
    Integer i1=Integer.valueOf(1);
    Integer i2=Integer.valueOf(1);
    System.out.println(i1==i2);//结果为true
  • 代码验证3:
    Integer i1=Integer.new(1);
    Integer i2=Integer.new(1);
    System.out.println(i1==i2);//结果为false
  • 代码验证4:
    Integer i1 =100;
    Integer i2 =100;
    if (i1 == i2){
    System.out.println("i1 == i2");
    } else {
    System.out.println("i1 != i2");
    }
    //输出i1==i2;
  • 代码验证5:
    Integer i1 =200;
    Integer i2 =200;
    if (i1 == i2){
    System.out.println("i1 == i2");
    } else {
    System.out.println("i1 != i2");
    }
    //输出i1!=i2;
  • 部分运行结果截图:

  • 理解情况:
  1. 由于Integer变量实际上是对一个Integer对象的引用,所以两个通过new生成的Integer变量永远是不相等的。(因为引用不相同)
  2. Integer变量和int变量比较时,只要两个变量的值是相等的,则结果为true。
    • 原因:因为包装类Integer和基本数据类型int比较时,java会自动拆包装为int,然后进行比较,实际上就变为两个int变量的比较。
    • 例如:Integet i1=100; 默认为Integer i1=Integer.valueOf(100)。
  3. 对于两个非new生成的Integer对象,进行比较时,如果两个变量的值在区间-128到127之间,则比较结果为true,如果两个变量的值不在此区间,则比较结果为false
    • 因为Integer有个默认范围-128-127。
    • 但你也可以通过如下指令修改范围:java -Djava.lang.Integer.IntegerCache.high=300;//将范围改为-128-300

四、String、StringBuffer、StringBuilder三者之间的区别

  • 代码验证1:
    String s1="hello"
String s2="hello"
System.out.println(s1 == s2);//输出结果为true
  • 代码验证2:
    String s1="hello";
String s2=s1;
System.out.println(s1 == s2);//输出结果为true
  • 代码验证3:
    String s1=new String("hello");
String s2=s1;
s1=s1+"world";
System.out.printlns(s1==s2);//输出结果为false
  • 代码验证4:
    StringBuilder s1=new StringBuilder("hello");
StringBuilder s2=s1;
s1=s1,append("hello");
System.out.printlns(s1==s2);//输出结果为true
  • 代码验证5:
    StringBuffer s1=new StringBuffer("hello");
StringBufferr s2=s1;
s1=s1,append("hello");
System.out.printlns(s1==s2);//输出结果为true
  • 部分运行结果截图:







  • 理解情况:
  1. String为字符串常量,而StringBuilder和StringBuffer均为字符串变量,即String对象一旦创建之后该对象是不可更改的,但后两者的对象是变量,是可以更改的。(String后面一旦加上一个字符串就重新new)
  2. StringBuilder类与StringBuffer类使用 append方法往后加字符串时不改变引用
  3. StringBuilder:适用于单线程下在字符缓冲区进行大量操作的情况
  4. StringBuffer:适用多线程下在字符缓冲区进行大量操作的情况,效率低

五、ArrayList类、Vector类、LinkedList类三者之间的区别

  • ArrayList类,动态,数组随机访问,访问任何一个元素所用的时间都是一致的 查找快
  • Vector类,多线程,并发时使用Vector
  • LinkedList链表,查找慢,插入删除快
  • 代码验证:
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.lang.Integer;
import java.util.Vector;
public class TestList {
public static List list = CreatList.creatList();
public static void main(String[] args) {
if (args[0].equals("0")) {
ArrayListTest();
}
if (args[0].equals("1")) {
VectorTest();
}
if (args[0].equals("2")) {
LinkListTest();
}
}
public static void ArrayListTest() {
ArrayList arrayList = new ArrayList(list);
int index3 = arrayList.indexOf(Integer.valueOf(35));
System.out.println(index3);
}
public static void VectorTest() {
Vector vector = new Vector(list);
int index3 = vector.indexOf(Integer.valueOf(35));
System.out.println(index3);
}
public static void LinkListTest() {
LinkedList linkedList = new LinkedList(list);
int index3 = linkedList.indexOf(35);
System.out.println(index3);
}
}
  • 运行结果截图:

六、HashMap、HashTable、TreeMap三者之间的区别

  • HashMap具有很快的访问速度。HashMap不支持线程的同步,即任一时刻可以有多个线程同时写HashMap,可能会导致数据的不一致。
  • Hashtable与HashMap类似,不同的是:它支持线程的同步,即任一时刻只有一个线程能写Hashtable,然而,这也导致了Hashtable在写入时会比较慢。
  • TreeMap能够把它保存的记录根据键排序,默认是按升序排序,也可以指定排序的比较器。当用Iteraor遍历TreeMap时,得到的记录是排过序的。
  • 代码验证:
    • 代码1:
    import java.util.Iterator;
    import java.util.Map;
    public class HashMap {
    public static void main(String[] args) {
    Map<String, String> map1= new java.util.HashMap<String, String>();
    map1.put("20175313","张黎仙");
    map1.put("20175314","薛勐");
    map1.put("20175312","陶光远");
    map1.put("20175316","盛茂淞");
    map1.put("20175311","胡济栋");
    map1.put("20175315","陈煜扬");
    long start1=System.currentTimeMillis();
    Iterator<Map.Entry<String, String>> it1 = map1.entrySet().iterator();
    while (it1.hasNext()) {
    Map.Entry<String, String> e = it1.next();
    System.out.println("Key: " + e.getKey() + "; Value: " + e.getValue());
    }
    }
    }
    • 代码2:
    import java.util.HashMap;
    import java.util.Hashtable;
    import java.util.Map;
    import java.util.TreeMap;
    import java.util.Iterator;
    public class HashTable {
    public static void main(String[] args) {
    Map<String, String> map= new Hashtable<String, String>();
    map.put("20175313","张黎仙");
    map.put("20175314","薛勐");
    map.put("20175312","陶光远");
    map.put("20175316","盛茂淞");
    map.put("20175311","胡济栋");
    map.put("20175315","陈煜扬");
    long start=System.currentTimeMillis();
    Iterator<Map.Entry<String, String>> it = map.entrySet().iterator();
    while (it.hasNext()) {
    Map.Entry<String, String> e = it.next();
    System.out.println("Key: " + e.getKey() + "; Value: " + e.getValue());
    }
    }
    }
    • 代码3:
    import java.util.Iterator;
    import java.util.Map;
    public class TreeMap {
    public static void main(String[] args) {
    Map<String, String> map2= new java.util.TreeMap<String, String>();
    map2.put("20175313","张黎仙");
    map2.put("20175314","薛勐");
    map2.put("20175312","陶光远");
    map2.put("20175316","盛茂淞");
    map2.put("20175311","胡济栋");
    map2.put("20175315","陈煜扬");
    long start2=System.currentTimeMillis();
    Iterator<Map.Entry<String, String>> it2 = map2.entrySet().iterator();
    while (it2.hasNext()) {
    Map.Entry<String, String> e = it2.next();
    System.out.println("Key: " + e.getKey() + "; Value: " + e.getValue());
    }
    }
    }
  • 运行结果截图:

七、码云链接

20175313 张黎仙《Java综合讲座》第十三周课堂测试总结的更多相关文章

  1. 20155233 《Java程序设计》 第十三周课堂练习总结

    20155233 <Java程序设计>第十三周课堂练习总结 测试题目 测试1 在IDEA中对P145 MathTool.java 使用JUnit进行单元测试,测试用例不少于三个,要包含正常 ...

  2. 20175313 张黎仙《Java程序设计》第九周学习总结

    目录 学号 20175313 <Java程序设计>第九周学习总结 一.教材学习内容总结 二.教材学习中的问题和解决过程 三.代码托管 四.心得体会 五.学习进度条 六.参考资料 学号 20 ...

  3. 20175313 张黎仙《获奖感想与Java阶段性学习总结》

    一.获奖感想 很荣幸能够成为为数不多的小黄衫获得者之一,这是对我近一学期以来学习成果的肯定,也激励着我更加努力学习. 首先我要感谢的人就是娄嘉鹏老师.我曾在师生关系中提到,我认为的好老师的特点之一是: ...

  4. 20175313 张黎仙《Java程序设计》第十一周学习总结

    目录 一.教材学习内容总结 二.教材学习中的问题和解决过程 三.代码托管 四.心得体会 五.学习进度条 六.参考资料 一.教材学习内容总结 第十三章内容 主要内容 URL类 InetAdress类 套 ...

  5. 20175313 张黎仙《Java程序设计》第十周学习总结

    目录 一.教材学习内容总结 二.教材学习中的问题和解决过程 三.代码调试中的问题和解决过程 四.代码托管 五.心得体会 六.学习进度条 七.参考资料 一.教材学习内容总结 第十二章内容 主要内容 杂项 ...

  6. 学号 20175201张驰 《Java程序设计》第8周学习总结

    学号 20175201张驰 <Java程序设计>第8周学习总结 教材学习内容总结 第十五章 知识总结: 1.泛型类声明:可以使用"class 名称"声明一个类,例如:c ...

  7. 学号 20175201张驰 《Java程序设计》第7周学习总结

    学号 20175201张驰 <Java程序设计>第7周学习总结 教材学习内容总结 第八章 String类能有效地处理字符序列信息,它的常用方法有: public int length()可 ...

  8. 学号 20175201张驰 《Java程序设计》第6周学习总结

    学号 20175201张驰 <Java程序设计>第6周学习总结 教材学习内容总结 第7章 ·1.Java支持在一个类中声明另一个类,这样的类称作内部类,而包含内部类的类称为内部类的外嵌类 ...

  9. 学号 20175201张驰 《Java程序设计》第5周学习总结

    学号 20175201张驰 <Java程序设计>第5周学习总结 教材学习内容总结 第六章 ·1.接口的接口体中只可以有常量和abstract方法. ·2.和类一样,接口也是Java中一种重 ...

随机推荐

  1. pdm文件打开方式

    转自:https://blog.csdn.net/qq_36855191/article/details/79299216 pdm打开网站:http://www.dmanywhere.cn/

  2. vue中将时间戳转换为YYYY-MM-dd hh:mm格式时间的组件

    首先我们可以使用vue中的过滤方法将数据变成另一个格式 // html <span class="rate-time">{{rating.rateTime | form ...

  3. Hystrix 熔断器

    Hystrix 是Netflix开源的一个延迟和容错库,用于隔离访问远程服务,防止出现级联失败 一.Hystrix 的定义 二.Hystrix 的原理 在分布式式系统中应用熔断器后,服务调用方可以自己 ...

  4. BPM业务流程管理系统_K2受邀出席QAD客户日活动,赋能企业云端智造_工作流引擎

    10月17日,K2受邀参加由厦门易维主办的以“走进QAD云ERP,深耕智能制造”为主题的QAD客户日活动.本次大会是以工业4.0背景下传统制造业面临巨大压力和挑战为导向,旨在探讨如何助力企业迅速适应业 ...

  5. pip3升级问题

    输入命令sudo pip3 install --upgrade pip 升级完成之后执行pip命令会报错,错误信息如下: File "/usr/bin/pip3", line 9, ...

  6. C#中的struct(结构)为值类型,struct类型全接触

    众所周知,struct类型和class类型非常相似,尤其是在C++中,class可以办到的事struct几乎都可以实现.在C#中struc类型依然存在,它的用处相对来说已经显得越来越不重要,这里主要讲 ...

  7. 【OF框架】搭建标准工作环境

    前言 统一工作环境,统一工具集,是沟通效率的基础.如同语言一样,使用不同语言的人,需要花更多的精力去理解语言,然后才是理解语言的内容,而使用相同语言的人,对话过程直接进入到内容.对于语言不统一增加的效 ...

  8. Redis4.0之持久化存储

    一,redis概述与实验环境说明 1.1 什么是redis redis是一种内存型的NoSQL数据库,优点是快,常用来做缓存用  redis存储数据的方法是以key-value的形式  value类型 ...

  9. 剑指Offer(三十一):整数中1出现的次数(从1到n整数中1出现的次数)

    剑指Offer(三十一):整数中1出现的次数(从1到n整数中1出现的次数) 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https:// ...

  10. Latex快速注释掉多行

    最简单的方法就是选中你想要注释掉的内容,同时按住Ctrl+Alt+Shift+→