当前位置:首页>开发>正文

java打印日志的几种方式 java中如何读取文件中内容,并打印日历

2023-05-20 20:22:31 互联网 未知 开发

 java打印日志的几种方式 java中如何读取文件中内容,并打印日历

java打印日志的几种方式

在Java 中实现记录日志的方式有很多种, 下面给你简单介绍四种:
1. 最简单的方式,就是system.println.out(error) ,这样直接在控制台打印消息了。
2. Java.util.logging 在JDK 1.4 版本之后,提供了日志的API ,可以往文件中写日志了。 

3. log4j , 最强大的记录日志的方式。 可以通过配置 .properties 或是 .xml 的文件, 配置日志的目的地,格式等等。 

4. commons-logging, 最综合和常见的日志记录方式, 经常是和log4j 结合起来使用。

java中如何读取文件中内容,并打印日历

public class ReadFromFile {
/**
* 以字节为单位读取文件,常用于读二进制文件,如图片、声音、影像等文件。
*/
public static void readFileByBytes(String fileName) {
File file = new File(fileName)
InputStream in = null
try {
System.out.println("以字节为单位读取文件内容,一次读一个字节:")
// 一次读一个字节
in = new FileInputStream(file)
int tempbyte
while ((tempbyte = in.read()) != -1) {
System.out.write(tempbyte)
}
in.close()
} catch (IOException e) {
e.printStackTrace()
return
}
try {
System.out.println("以字节为单位读取文件内容,一次读多个字节:")
// 一次读多个字节
byte[] tempbytes = new byte[100]
int byteread = 0
in = new FileInputStream(fileName)
ReadFromFile.showAvailableBytes(in)
// 读入多个字节到字节数组中,byteread为一次读入的字节数
while ((byteread = in.read(tempbytes)) != -1) {
System.out.write(tempbytes, 0, byteread)
}
} catch (Exception e1) {
e1.printStackTrace()
} finally {
if (in != null) {
try {
in.close()
} catch (IOException e1) {
}
}
}
}

/**
* 以字符为单位读取文件,常用于读文本,数字等类型的文件
*/
public static void readFileByChars(String fileName) {
File file = new File(fileName)
Reader reader = null
try {
System.out.println("以字符为单位读取文件内容,一次读一个字节:")
// 一次读一个字符
reader = new InputStreamReader(new FileInputStream(file))
int tempchar
while ((tempchar = reader.read()) != -1) {
// 对于windows下, 这两个字符在一起时,表示一个换行。
// 但如果这两个字符分开显示时,会换两次行。
// 因此,屏蔽掉 ,或者屏蔽 。否则,将会多出很多空行。
if (((char) tempchar) != ) {
System.out.print((char) tempchar)
}
}
reader.close()
} catch (Exception e) {
e.printStackTrace()
}
try {
System.out.println("以字符为单位读取文件内容,一次读多个字节:")
// 一次读多个字符
char[] tempchars = new char[30]
int charread = 0
reader = new InputStreamReader(new FileInputStream(fileName))
// 读入多个字符到字符数组中,charread为一次读取字符数
while ((charread = reader.read(tempchars)) != -1) {
// 同样屏蔽掉 不显示
if ((charread == tempchars.length)
&& (tempchars[tempchars.length - 1] != )) {
System.out.print(tempchars)
} else {
for (int i = 0 i < charread i ) {
if (tempchars[i] == ) {
continue
} else {
System.out.print(tempchars[i])
}
}
}
}

} catch (Exception e1) {
e1.printStackTrace()
} finally {
if (reader != null) {
try {
reader.close()
} catch (IOException e1) {
}
}
}
}

/**
* 以行为单位读取文件,常用于读面向行的格式化文件
*/
public static void readFileByLines(String fileName) {
File file = new File(fileName)
BufferedReader reader = null
try {
System.out.println("以行为单位读取文件内容,一次读一整行:")
reader = new BufferedReader(new FileReader(file))
String tempString = null
int line = 1
// 一次读入一行,直到读入null为文件结束
while ((tempString = reader.readLine()) != null) {
// 显示行号
System.out.println("line " line ": " tempString)
line
}
reader.close()
} catch (IOException e) {
e.printStackTrace()
} finally {
if (reader != null) {
try {
reader.close()
} catch (IOException e1) {
}
}
}
}

/**
* 随机读取文件内容
*/
public static void readFileByRandomAccess(String fileName) {
RandomAccessFile randomFile = null
try {
System.out.println("随机读取一段文件内容:")
// 打开一个随机访问文件流,按只读方式
randomFile = new RandomAccessFile(fileName, "r")
// 文件长度,字节数
long fileLength = randomFile.length()
// 读文件的起始位置
int beginIndex = (fileLength > 4) ? 4 : 0
// 将读文件的开始位置移到beginIndex位置。
randomFile.seek(beginIndex)
byte[] bytes = new byte[10]
int byteread = 0
// 一次读10个字节,如果文件内容不足10个字节,则读剩下的字节。
// 将一次读取的字节数赋给byteread
while ((byteread = randomFile.read(bytes)) != -1) {
System.out.write(bytes, 0, byteread)
}
} catch (IOException e) {
e.printStackTrace()
} finally {
if (randomFile != null) {
try {
randomFile.close()
} catch (IOException e1) {
}
}
}
}

/**
* 显示输入流中还剩的字节数
*/
private static void showAvailableBytes(InputStream in) {
try {
System.out.println("当前字节输入流中的字节数为:" in.available())
} catch (IOException e) {
e.printStackTrace()
}
}

public static void main(String[] args) {
String fileName = "C:/temp/newTemp.txt"
ReadFromFile.readFileByBytes(fileName)
ReadFromFile.readFileByChars(fileName)
ReadFromFile.readFileByLines(fileName)
ReadFromFile.readFileByRandomAccess(fileName)
}
}

如何用java编写带打印功能的记事本



http://www.ibm.com/developerworks/cn/java/l-javaprint/

放心点,ibm开发库,
介绍打印的非常全
如果这都学不会那我也没办法了

java项目中打印log

根据我个人的经验来说,开发阶段使用debug级别、测试阶段使用info级别、上线后可以继续维持在info级别、上线一段时间后,可以改成error级别。
根据你的描述,应该是使用info级别,具体使用情况大致是这样:
1. 每一个操作都要记录的话,使用log.info("要记录的内容");
2. 对于某些错误,如果不影响流程可以考虑使用log.warn("要记录的内容");
3. 对于严重错误,如空指针、内存溢出等,使用log.error("要记录的内容");

最新文章