SCJP笔记整理(六)

2024-01-03 08:18
文章标签 整理 笔记 scjp

本文主要是介绍SCJP笔记整理(六),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

说明:这是2007年复习SCJP期间的学习笔记(JavaSE 5.0),有部分遗失。现在整理一下发到Blog上,一方面做个备份,另一方面分享出来,希望对需要的人有用。

-----------------------------------

第六部分 字符串、I/O、格式化、解析

1、在程序中大量的String常量内往往有大量的冗余,JVM留出一块特殊的内存区域。JVM留出一块特殊的内存区域,称作“String常量池”。

2String类的方法:

charAt(int index):返回位于指定索引处的字符,String索引从0开始。

concat(String s):追加字符串到另一个字符串末尾。

substring(int begin,int end):第一个参数从0开始,代表起始位置。第二个参数从1开始,代表结束位置。

3StringBufferStringBuilder类型对象能够被反复修改,而不会遗留下大批丢弃String对象这样的重大问题。StringBuilder类不是线程安全的。

4StringBuilder的方法:

delete(int start,int end):第一个参数从0开始,第二个参数从1开始。

insert(int offset,String s):插入的偏移量,从0开始。

reverse():颠倒字符。

5File类创建文件:

try{  //文件操作必须放在try-catch中。

      File file = new File(“a.txt”);

      file.createNewFile(); //若不存在该文件,则创建文件。

      file.exists();  //若能找到实际的文件,则返回true

   }catch(IOException e){

   e.printStackTrace();

}

6FileWriter\FileReader

   char[] in=new char[30];

   Try{

     File file=new File(“a.txt”);

     FileWriter fw=new FileWriter(file);

     fw.write(“aaaaaaaa\n”);

     fw.flush();

     fw.close();

    

     FileReader fr=new FileReader(file);

     fr.read(in);

     for(char c:in){

  System.out.print(c);

}

fr.close();

}catch(IOException e){}

7BufferedWriter\BufferedReader

   BufferedWriter构造函数参数Writer.

   BufferedReader构造函数参数Reader.

8PrintWriter构造函数参数:Writer\File\String\OutputStream.

9、处理FileDirectory

   File mydir=new File(“java”);

   mydir.mkdir();

   File myfile=new File(mydir,”a.txt”);  //mydir不存在则抛出IOException.

   myfile.createNewFile();

   //文件不存在会自动创建,目录则不会。

10Filedelete()方法:若删除目录,则必须目录为空,否则返回false

          renameTo()方法:给现有File对象一个新File对象(重命名),也可以重命名一个不为空的目录。

list()方法:File file=new File(“searchdir”);

String[] result=file.list(); //list方法返回一个String数组。

for(String fn : result){ //result包含searchdir下的目录、文件名。

  System.out.println(“found ”+ fn);

}

11、显示的把一个变量标识为transient,则该变量的值不会被串行化。

12ObjectOutputStream\ObjectInputStream

ObjectOutputStream.writeObject();  //Serializable and write

ObjectInputStream.readObject();    //Serializable and read

 

try{

   FileOutputStream fos=new FileOutputStream(“a.ser”);

   ObjectOutputStream oos=new ObjectOutputStream(fos);

   oos.writeObject(serObject); //这是一个实现了Serializable接口的实例。

   oos.close();

}catch(IOExecption e){}

 

try{

   FileInputStream fis=new FileInputStream(“a.ser”);

   ObjectInputStream ois=new ObjectInputStream(fis);

   serObject=(Ser)ois.readObject();  //取出对象转型为其原来类型。

   ois.close();

}catch(IOException e){}

13、若某个不可串行化的对象标识为transient,则反串行化时该对象为空,解决方案:

Class Dog implements Seriallizable{

    transient private Collar theCollar;

    private int dogSize;

    ……

    private void writeObject(ObjectOutputStream oos){

        try{

           oos.defaultWriteObject(); //执行正常的串行化过程。

           oos.writeInt(theCollar.getSize());

}catch(Exception e){

}

}

 

    private void readObject(ObjectInputStream ois){

          try{

             ois.defaultReadObject();//必须与写入相同的顺序读出。

             theCollar=new Collar(ois.readInt());

}catch(Exception e){

}

}

}

14、反串行化一个对象时,我们不希望发生任何正常的初始化。反串行化可串行化类实例时,构造函数不会运行,并且不会给实例变量提供它们最初的赋值。

   当子类是可串行化而父类不可串行化时,那么从父类继承的所有实例变量都将被重置为它们在对象原始构造期间所赋予的值。

   如果串行化一个数组或集合,则其中的每个元素都必须都是可串行化的。

   静态变量永远不会保存为对象状态的一部分。

15、日期:

   Java.util.Date  //连续CalendarDateFormat的桥梁。

   Java.util.Calendar  //日期,时间类。

   Java.text.DateFormat  //格式化日期类。

   Java.text.NumberFormat  //格式化各地区数字和货币。

   Java.util.Locale   //格式化特定地区日期、数字、货币。

16Date类:

    setTime()getTime()都使用毫秒计数法。

17Calendar类:

Date d1=new Date(10000000);

Calendar cal= Calendar.getInstance();  //静态方法创建日期实例.

cal.setTime(d1);

cal.add(Calendar.MONTH,1); //月份+1,或添加负值(减)。

Date d2=cal.getTime();

System.out.println(“date: ” + d2.toString());

另一种方式:

Calendar cal=Calendar.getInstance();

cal.setTime(d1);

cal.roll(Calendar.MONTH,9);   //不会增减时间中更大的部分。月份到12后返回1月,年不增长。

Date d3=cal.getTime();

System.out.println(“date: ” + d3.toString());

18DateFormat类:

format方法:时间格式化为字符串。

parse方法:字符串转化为时间。

Date d=new Date(100000000);

DateFormat df=DateFormat.getDateInstance(DateFormat.SHORT); //静态方法创建

String s=df.format(d);  //DateFormat.format方法返回格式化后的时间字符串。

System.out.println(“date: ” + s);

Date d1=df.parse(s);   //字符串转化为时间。

System.out.println(“date: ” + d1.toString());

Date转换为String会损失一些精度.

19Locale类:Locale loc = new Locale(“it”);  //意大利语。

    例:按某地区使用的语言显示时间。

    Date d=new Date(100000000000);

Locale locIT = new Locale(“it”,”CH”);  //瑞士使用的意大利语。

DateFormat dfIT=DateFormat.getDateInstance(DateFormat.FULL,locIT);

String s=dfIT.format(d);

System.out.println(“date: ” + s);

Locale类中的两个方法:

getDisplayCountry():某地区的国家的名称。

getDisplayLanguage():某地区的语言的名称。

20NumberFormat类:

float f=345.678f;

Locale locfr=new Locale(“fr”); 

//默认的格式化float显示。

NumberFormat nfa1=NumberFormat.getInstance();

String s1=nfa1.format(f);

System.out.println(“Number: ” + s1);

//包含地区的格式化显示。

NumberFormat nfa2= NumberFormat.getInstance(locfr);

String s2=nfa2.format(f);

System.out.println(“Number: ” + s2);

//默认的货币格式化。

NumberFormat nfa3=NumberFormat.getCurrencyInstance();

String s3=nfa3.format(f);

System.out.println(“Currency: ” + s3);

//包含地区的货币格式化。

NumberFormat nfa4=NumberFormat.getCurrencyInstance(locfr);

String s4=nfa4.format(f);

System.out.println(“Currency: ” + s4);

 

NumberFormat中的方法:

getMaximumFractionDigits():获取最大小数位数,默认为3

setMaximumFractionDigits():设置最大小数位数。

parse():将String转换为数值型,该方法必须在try-catch中运行。

setFormatIntegerOnly():只取整数位。

例:

float f=1234.5678f;

Numberformat nfa=NumberFormat.getInstance();

String s1=nfa. getMaximumFractionDigits();  //默认最大小数位为3

System.out.println(s1+ “ ” + nf.format(f));

//设置为5

nfa. setMaximumFractionDigits(5); //设置最大小数位为5

String s2=nfa. getMaximumFractionDigits();

System.out.println(s2+ “ ” + nf.format(f));

//

try{

    String s3=nfa.parse(“12345.678”);

    nfa. setFormatIntegerOnly(true);  //设置只取整数部分。

    String s4=nfa.parse(“12345.678”);

    System.out.println(s3+ “ ” + s4);

}catch(ParseException e){

    e.printStackTrace();

}

这篇关于SCJP笔记整理(六)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/565045

相关文章

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

论文阅读笔记: Segment Anything

文章目录 Segment Anything摘要引言任务模型数据引擎数据集负责任的人工智能 Segment Anything Model图像编码器提示编码器mask解码器解决歧义损失和训练 Segment Anything 论文地址: https://arxiv.org/abs/2304.02643 代码地址:https://github.com/facebookresear

数学建模笔记—— 非线性规划

数学建模笔记—— 非线性规划 非线性规划1. 模型原理1.1 非线性规划的标准型1.2 非线性规划求解的Matlab函数 2. 典型例题3. matlab代码求解3.1 例1 一个简单示例3.2 例2 选址问题1. 第一问 线性规划2. 第二问 非线性规划 非线性规划 非线性规划是一种求解目标函数或约束条件中有一个或几个非线性函数的最优化问题的方法。运筹学的一个重要分支。2

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

查看提交历史 —— Git 学习笔记 11

查看提交历史 查看提交历史 不带任何选项的git log-p选项--stat 选项--pretty=oneline选项--pretty=format选项git log常用选项列表参考资料 在提交了若干更新,又或者克隆了某个项目之后,你也许想回顾下提交历史。 完成这个任务最简单而又有效的 工具是 git log 命令。 接下来的例子会用一个用于演示的 simplegit

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

忽略某些文件 —— Git 学习笔记 05

忽略某些文件 忽略某些文件 通过.gitignore文件其他规则源如何选择规则源参考资料 对于某些文件,我们不希望把它们纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。通常它们都是些自动生成的文件,比如日志文件、编译过程中创建的临时文件等。 通过.gitignore文件 假设我们要忽略 lib.a 文件,那我们可以在 lib.a 所在目录下创建一个名为 .gi

取得 Git 仓库 —— Git 学习笔记 04

取得 Git 仓库 —— Git 学习笔记 04 我认为, Git 的学习分为两大块:一是工作区、索引、本地版本库之间的交互;二是本地版本库和远程版本库之间的交互。第一块是基础,第二块是难点。 下面,我们就围绕着第一部分内容来学习,先不考虑远程仓库,只考虑本地仓库。 怎样取得项目的 Git 仓库? 有两种取得 Git 项目仓库的方法。第一种是在本地创建一个新的仓库,第二种是把其他地方的某个