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

相关文章

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Mysql中深分页的五种常用方法整理

《Mysql中深分页的五种常用方法整理》在数据量非常大的情况下,深分页查询则变得很常见,这篇文章为大家整理了5个常用的方法,文中的示例代码讲解详细,大家可以根据自己的需求进行选择... 目录方案一:延迟关联 (Deferred Join)方案二:有序唯一键分页 (Cursor-based Paginatio

Mysql中InnoDB与MyISAM索引差异详解(最新整理)

《Mysql中InnoDB与MyISAM索引差异详解(最新整理)》InnoDB和MyISAM在索引实现和特性上有差异,包括聚集索引、非聚集索引、事务支持、并发控制、覆盖索引、主键约束、外键支持和物理存... 目录1. 索引类型与数据存储方式InnoDBMyISAM2. 事务与并发控制InnoDBMyISAM

StarRocks索引详解(最新整理)

《StarRocks索引详解(最新整理)》StarRocks支持多种索引类型,包括主键索引、前缀索引、Bitmap索引和Bloomfilter索引,这些索引类型适用于不同场景,如唯一性约束、减少索引空... 目录1. 主键索引(Primary Key Index)2. 前缀索引(Prefix Index /

数论入门整理(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的原因是这个