0

0

Java中Properties类为什么继承自Hashtable_配置文件读取的历史设计缺陷

P粉602998670

P粉602998670

发布时间:2026-03-18 10:34:02

|

999人浏览过

|

来源于php中文网

原创

Properties是Hashtable子类因Java 1.0无Map接口,只能复用线程安全的Hashtable存String键值,靠文档和重写方法约束类型,属历史包袱;load/store默认ISO-8859-1编码致中文乱码,应改用load(Reader)或loadFromXML();getProperty与get行为不一致且null处理不同;其synchronized方法不保证业务级线程安全,现代应用宜用不可变配置对象替代。

java中properties类为什么继承自hashtable_配置文件读取的历史设计缺陷

Properties 为什么是 Hashtable 的子类

因为 Java 1.0 时代没有 Map 接口,Hashtable 是当时唯一的线程安全键值容器。设计者直接复用它来存配置项——key 和 value 都是 String,但 Hashtable 要求泛型为 Object,于是靠文档和重写方法(如 setProperty)强行约束类型。

这不是权衡后的选择,是历史包袱:1995 年连接口都还没抽象出统一的 Map,更别说泛型了。后来加了 Map 接口,但为了二进制兼容,Properties 不能改继承关系。

load() 方法默认只支持 ISO-8859-1 编码

读取含中文的配置文件时,load(InputStream) 会把非 Latin-1 字符解码成乱码,哪怕文件本身是 UTF-8。这是最常踩的坑。

  • load(Reader) 替代:传入 new InputStreamReader(in, "UTF-8")
  • 或改用 loadFromXML(),它原生支持 UTF-8,且格式更规范
  • store() 同理,默认也按 ISO-8859-1 写,中文会变问号

getProperty() 和 get() 行为不一致

getProperty(String key) 返回 Stringnull;而继承自 Hashtableget(Object key) 返回 Object,且对 null key 抛 NullPointerException ——但 Properties 实际允许 key 为 null(只是不推荐)。

立即学习Java免费学习笔记(深入)”;

简单搜索
简单搜索

简单搜索-全新AI互动式搜索,能听会看,聪明懂你

下载

更隐蔽的问题是:如果配置里写的是 debug=truegetProperty("debug") 返回 "true",但 get("debug") 也返回 "true"(因为底层还是 Hashtable.get())。表面一样,可一旦你用 put("debug", Boolean.TRUE) 手动塞了个非字符串值进去,getProperty() 就返回 null,而 get() 还能取到。

线程安全是假象,实际并不适合并发修改

Properties 继承 Hashtable,所有 public 方法都 synchronized,看起来线程安全。但真实场景中,配置读多写少,且「读取后解析逻辑」往往跨多个 getProperty() 调用——比如先读 db.url,再读 db.user,中间若被其他线程 reload,状态就可能不一致。

  • 别依赖它的 synchronized 做业务同步,reload 本身不是原子操作
  • 现代应用应把配置抽象为不可变对象(如用 Config 类封装),加载完就冻结
  • 如果真要热更新,用 ConcurrentHashMap + 显式锁,而不是靠 Properties 的老式同步

它从设计第一天起就不是为动态配置服务的,只是个带换行/注释支持的字符串字典。现在还用它做核心配置管理,等于在用锤子拧螺丝——能转,但吃力,还容易滑丝。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1091

2023.08.02

java中boolean的用法
java中boolean的用法

在Java中,boolean是一种基本数据类型,它只有两个可能的值:true和false。boolean类型经常用于条件测试,比如进行比较或者检查某个条件是否满足。想了解更多java中boolean的相关内容,可以阅读本专题下面的文章。

367

2023.11.13

java boolean类型
java boolean类型

本专题整合了java中boolean类型相关教程,阅读专题下面的文章了解更多详细内容。

43

2025.11.30

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

256

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1154

2024.03.01

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1571

2023.10.24

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

3

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.5万人学习

C# 教程
C# 教程

共94课时 | 11.5万人学习

Java 教程
Java 教程

共578课时 | 83.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号