JAVA 第七周学习总结

20175308 2018-2019-2 《Java程序设计》第七周学习总结

教材学习内容总结

本周学习第八章:常用实用类

String类:

  1. String类位于java.lang包中,被定义为final类,不可扩展,不可以有子类。
  2. 两种新的构造方式:
char a[] = {'J','a','v','a'};
String s = new String(a);

String(char a[],int startIndex,int count)
startIndex:起始位置
count:字符个数

(从字符数组中从startIndex起取count个字符构成字符串)

  1. 字符的并置运算:通过“+”进行并置运算
    参加并置运算的只要有一个为变量,新生成的字符串都会在动态区,相当于new String (....),如果都是常量,正常放入常量池中
    4.方法一览:
public int length():获取字符串长度;
public boolean equals(String s):比较字符串内容是否相同(比较内容,无所谓如何生成的字符串);
public boolean startWith(String s)
public boolean endWith(String s):判断字符串是否由参数s开头/结尾;
public int compareTo(String s):按字典序与参数指定的s比较大小(相等返回0,大于s返回整数,小于s返回负数);
public boolean contain(String s):判断字符串中是否包含参数s;
public int indexOf(String s)
public int lastindexOf(String s):返回s在字符串中首次/最后一次出现的位置(位置从0开始算);
public String substring(int startpoint):获得一个新的字符串,从原字符串的startpoint位置直到最后一个字符都复制下来;
public String trim():返回当前String对象去掉前后空格后的字符序列。

5.与字符数组、字节数组:
将字符串中的字符序列放入字符数组的方法:
public void getChars(int start,int end,char c[],int offset)(起始位置,种植位置,字符数组名称,放入字符数组的位置)
将指定的字节数组byte构成String对象的方法:
String(byte[],int offset,int length)
6.正则表达式:
public boolean matches (String regex)判断当前String对象的字符是否和正则表达式相匹配。
public String replaceAll(String regex,String replacement)返回一个String对象,将原字符串中所有与正则表达式相匹配的字符序列换成replacement后得到的字符序列。

StringTokenizer类:

  • 两种构造方法:
    1.StringTokenizer(String s)对s进行分解,分隔标记使用默认的空格、换行、回撤、Tab等
    2.StringTokenizer(String s,String delim)以delim为分隔标记(delim中字符的任何序列
  • has MoreTokens():如果字符串中还有内容返回true,否则返回false
  • countTokens():以字符串全长为初值,分析一个后减一

    Scanner类:

    Scanner类对象也可以解析字符序列中的单词。useDelimiter(正则表达式)以正则表达式为分隔字符。next()依次返回被解析字符序列中的单词,如果最后一个单词也被返回,那么hasNext()将返回false。
    与StringTokenizer的区别:都可以用于分解字符序列中的单词,但思路不同,StringTokenizer将分解出的单词全部存放在对象的实体中,因此获得单词速度较快,但占用空间Scanner仅仅存放怎样获得单词的分隔标记,获得单词的速度较慢,但节省空间

    StringBuffer类:

    与String类不同,StringBuffer类的对象的实体的内存空间可以自动改变大小,便于存放一个可变的序列。
    三个构造方法

StringBuffer():自动分配初始容量容纳16个字符,大于16则重新分配;
StringBuffer(int size):指定分配实体空间的容量为size;
StringBuffer(String s):指定分配空间为s长度再加16

常用方法:

1.append方法:追加;
2.public char charAt(int n):得到StringBuffer字符序列位置n上的字符;
3.public void setCharAt(int n,char ch):将当前对象字符序列位置n上的字符用ch指定的字符替换;
4.StringBuffer insert(int index,String str):使用insert方法将参数str指定的字符序列插入index指定的位置,并返回当前对象的引用;
5.public StringBuffer reverse():将对象实体中的字符序列翻转并返回引用;
6.StringBuffer delete(int startIndex,int endIndex):从startIndex到endIndex-1删除字符并返回引用;
7.StringBuffer replace(int startIndex,int endIndex,String str):替换字符。

Math类:

Math类中存放着许多可以进行科学计算的static方法,这些方法都可一直接通过类名调用。
方法一览:

1.public static long abs(double a):返回a的绝对值;
2.public static double max(double a,double b):返回a,b的最大值;
3.public static double min(double a,double b):返回a,b的最小值;
4.public static double random():产生一个0~1之间的随机数(不包括0和1);
5.public static double pow(double a,double b):返回a的b次幂;
6.public static double sqrt(double a):返回a的平方根;
7.public static double log(double a):
返回a的对数;
8.public static double sin(double a):返回a的正弦值;
9.public static double asin(double a):返回a的反正弦值;
10.public static double ceil(double a):返回大于a的最小整数(转化成double类型);
11.public static double floor(double a):返回小于a的最大整数(转化成double类型);
12.public static long round(double a):返回四舍五入后的值。

教材学习中的问题和解决过程

本次学习任务为第八章,里面介绍了常用实用类的基本介绍和用法。有不少类都在之前的学习中有所使用,所以说不上多难,但是对这么多类同时进行系统的学习和驳杂概念的记忆着实是一个不小的挑战,只能尽量挑着重点有选择的记忆。但这种填鸭的记忆并不牢靠,还要靠今后的练习一点点的深入理解。

代码调试中的问题和解决

  • 问题:在对教材Example8_12的练习中,我得到了以下结果:

,这与程序正确的结果不符。
问题的解决:仔细观察结果,结果中只计错了商品数量,而商品总价值是正确的,问题必定出现在getGoodsAmount()中。

如图可见,我的StringTokenizer fenxi = new StringTokenizer(shoppingReceipt)忘记标注分隔符号“#”,即StringTokenizer fenxi = new StringTokenizer(shoppingReceipt,"#")。代码本意是将除数字以外的字符全都替换成“#”,然后以“#”为分隔符号分析字符串,这样有几个数字作为价格,就有几个商品。缺少了“#”,就只能计算一个商品。

代码托管

感悟

实话说最近感觉到学习越来越吃力,可能是清明假期出游浪费了太多时间,现在很明显的感觉时间不够用,需要记忆学习的内容太多,需要重新找到一个行之有效的方法改变现在这种状况。

原文地址:https://www.cnblogs.com/darklord0604/p/10706460.html

时间: 2024-08-03 23:53:28

JAVA 第七周学习总结的相关文章

20165326 java第七周学习笔记

第七周学习笔记 MySQL(数据管理系统)学习 知识点总结: 不能通过关闭MySQL数据库服务器所占用的命令行窗口来关闭MySQL数据库. 如果MySQL服务器和MySQL管理工具驻留在同一台计算机上,主机名可以是localhost或127.0.0.1. JDBC是允许用户在不同数据库之间做选择的一个抽象层.JDBC允许开发者用JAVA写数据库应用程序,而不需要关心底层特定数据库的细节. 查询操作: 向数据库发送SQL查询语句,先用statement声明对象,已创建的连接对象调用creatSta

java第七周学习总结

学号20145336 <Java程序设计>第3周学习总结 教材学习内容总结 Lambda 在我们编写程序时,可以使用Lambda特性去除重复的信息.Lambda表达式中this的参考对象以及toString()的接受者,是来自Lambda的周围环境,也就是看Lambda表达式是在哪个名称范畴,就能参考该范畴内的名称,像是变量或方法.Lambda表达式只是定义函数接口操作的一种方式,除此之外,只要静态方法的方法签署中,参数与返回值定义相同,也可以使用静态方法来定义函数接口操作.在只有Lambda

java第七周学习 jdk1.5新特性

eclipse中常用的快捷键 Alt + /   提示 Ctrl + / 单行注释 / 取消 Ctrl + Shift + / 多行注释 Ctrl + Shift + \ 取消多行注释 Ctrl + 1  快速修复 Ctrl + Shift + o 导包 Alt+上下键       代码位置调换 1.Ctrl + D            删除当前行 重置透视图:window->reset perspective 当eclipse 的Java视图变的很乱的时候,就可以重置透视图,还原为最初的界面

20145237 《Java程序设计》第七周学习总结

20145237 <Java程序设计>第七周学习总结 教材学习内容总结 第十三章   一.认识时间与日期   1.时间的度量   在正式认识Java提供了哪些时间处理API之前,得先来了解一些时间.日期的历史问题,这样你才会知道,时间日期确实是个很复杂的问题,而使用程序来处理时间日期,也不仅仅是使用API的问题.   a.格林威治标准时间:格林威治标准时间简称GMT时间,一开始是参考自格林威治皇家天文台的标准太阳时间,格林威治标准时间的正午是太阳抵达天空最高点之时,格林威治标准时间常被不严谨的

20145311 《Java程序设计》第七周学习总结

20145311 <Java程序设计>第七周学习总结 教材学习内容总结 第十二章 Lambda Lambda表达式会使程序更加地简洁,在平行设计的时候,能够进行并行处理. 第十三章 时间与日期 13.1Time&&Date 13.1.1时间的度量 1.Greenwich Mean Time(格林威治时间)简称GMT时间 观察太阳得来2.Universal Time(世界时)UT3.International Atomic Time(国际原子时)TAI4.Coordinated

20165235 祁瑛 2018-4 《Java程序设计》第七周学习总结

20165235 祁瑛 2018-4 <Java程序设计>第七周学习总结 教材学习内容总结 MySQL数据管理系统 MySQL数据管理系统,简称MySQL,是世界上流行的数据管理系统. MySQL是网络数据库管理系统,可以使远程的计算机访问它所管理的数据库. 在Windows上下载好MySQL后,进入Windows命令行,进入MySQL的bin文件目录输入--initialize-insecure对MySQL的data目录进行初始化.然后可以在bin目录下再次输mysql启用MySQL.启用M

20172328 2018-2019《Java软件结构与数据结构》第七周学习总结

20172328 2018-2019<Java软件结构与数据结构>第七周学习总结 概述 Generalization 本周学习了第11章:二叉查找树.在本章中,主要探讨了二叉查找树的概念和各种二叉查找树实现,考察为二叉查找树添加和删除元素的算法以及维护平衡二叉查找树的算法 教材学习内容总结 A summary of textbook 二叉查找树(binary search tree):二叉树定义的扩展,一种带有附加属性的二叉树.附加属性是什么?树中的每个节点,其左孩子都要小于其父节点,而父节点

2018-2019-20172329 《Java软件结构与数据结构》第七周学习总结

2018-2019-20172329 <Java软件结构与数据结构>第七周学习总结 教材学习内容总结 <Java软件结构与数据结构>第十一章-二叉查找树 一.概述 1.什么是二叉查找树:二叉查找树是一种带有附加属性的二叉树,即对树中的每个结点,其左孩子都要小于其父结点,而父结点又小于或等于其右孩子. 2.二叉查找树的定义是二叉树定义的扩展. 3.操作: 操作 描述 addElement 往树中添加一个元素 removeElement 从书中删除一个元素素 removeAllOccu

2018-2019-20172321 《Java软件结构与数据结构》第七周学习总结

2018-2019-20172321 <Java软件结构与数据结构>第七周学习总结 教材学习内容总结 第11章 二叉查找树 一.概述 二叉查找树是一种含有附加属性的二叉树,该属性即其左孩子小于父节点,而父节点又小于等于其右孩子.如下图所示.根结点的左子树每个元素都小于80,右子树每个元素都大于80. 查找方法,要判定一个具体的目标是否存在于树中,需要沿着从根开始的路径,根据查找目标是小于还是大于当前结点的值,相应地转到当前结点的左子结点或右结点.最终或是找到目标元素,或是遇到路径的末端,后者意