硬编码是指将特定的值或参数直接写入代码中的做法。这样的代码缺乏灵活性,当需要更改这些值或参数时,开发人员必须手动修改代码。这种方法不仅浪费时间,而且容易出错,并且不利于维护。相反,通过使用配置文件或数据库等外部资源,可以将这些值或参数作为参数传递给代码,并使代码更加灵活。
(资料图片)
在软件开发中,硬编码是一种常见的错误实践。它不仅会导致代码变得难以维护和扩展,还会降低代码的可重用性。下面,我们将通过几个示例来说明硬编码的问题,并介绍如何避免它。
假设我们正在开发一个Web应用程序,该应用程序需要向外部API发送HTTP请求以获取数据。如果我们将API的URL硬编码到我们的代码中,代码就会变得非常脆弱。任何时间,如果API的URL发生了变化,我们都必须手动更改代码中的URL。如果我们的代码分散在多个地方,这个过程就会变得非常痛苦。
以下是一个使用硬编码URL的示例:
public class ApiClient { private static final String API_URL = "https://api.example.com"; public ApiResponse callApi(String endpoint) { String url = API_URL + endpoint; // 发送HTTP请求并返回响应 }}
在这个例子中,API_URL 被硬编码为字符串常量,而且作为一个私有的静态常量,也就意味着该值在整个类中是可见的。如果我们要修改API的URL,我们需要手动修改该常量的值。
为了避免硬编码的URL,我们可以将URL作为参数传递给 callApi()
方法:
public class ApiClient { public ApiResponse callApi(String apiUrl, String endpoint) { String url = apiUrl + endpoint; // 发送HTTP请求并返回响应 }}
在这个例子中,我们将API_URL 变为方法的参数,并使用该参数构建URL。现在,我们可以通过将API_URL传递给该方法来调用该方法。
在开发Web应用程序时,我们通常需要访问数据库以获取或保存数据。为了访问数据库,我们需要连接到数据库服务器并执行SQL查询。如果我们将数据库连接信息硬编码到代码中,代码就会变得非常脆弱。
以下是一个使用硬编码数据库连接信息的示例:
public class UserDao { private static final String DB_URL = "jdbc:mysql://localhost/mydb"; private static final String DB_USERNAME = "root"; private static final String DB_PASSWORD = "password"; public List getAllUsers() { List userList = new ArrayList<>(); try { Connection conn = DriverManager.getConnection(DB_URL, DB_USERNAME, DB_PASSWORD); PreparedStatement stmt = conn.prepareStatement("SELECT * FROM users"); ResultSet rs = stmt.executeQuery(); while (rs.next()) { User user = new User(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); user.setEmail(rs.getString("email")); userList.add(user); } rs.close(); stmt.close(); conn.close(); } catch (SQLException e) { e.printStackTrace(); } return userList; }}
在这个例子中,DB_URL、DB_USERNAME和DB_PASSWORD都被硬编码为字符串常量。如果我们要连接到不同的数据库或使用不同的用户名和密码,我们必须手动更改这些常量的值。
为了避免硬编码的数据库连接信息,我们可以将这些信息存储在配置文件中,并在运行时从文件中读取这些信息。下面是一个使用配置文件的示例:
public class UserDao { private static final String CONFIG_FILE = "/path/to/config.properties"; public List getAllUsers() { List userList = new ArrayList<>(); try { Properties props = new Properties(); props.load(new FileInputStream(CONFIG_FILE)); String url = props.getProperty("db.url"); String username = props.getProperty("db.username"); String password = props.getProperty("db.password"); Connection conn = DriverManager.getConnection(url, username, password); PreparedStatement stmt = conn.prepareStatement("SELECT * FROM users"); ResultSet rs = stmt.executeQuery(); while (rs.next()) { User user = new User(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); user.setEmail(rs.getString("email")); userList.add(user); } rs.close(); stmt.close(); conn.close(); } catch (IOException | SQLException e) { e.printStackTrace(); } return userList; }}
在这个例子中,我们使用一个配置文件存储数据库连接信息。我们可以在运行时读取该文件,并从中获取连接信息。这种方法使我们可以轻松地更改连接信息,而无需修改代码。
标签:
仓储物流“成渝圈”如何乘势而上? 12月3日,连接昆明和万象的中老铁路全线开通运营,被惠及的显...
两件西周青铜簋时隔三千年成功配对 考古工作者介绍,这个铜簋的盖、身分别时隔40余年出土,纹饰...
“医保砍价”不是一个人在战斗 晁星 “我眼泪都快掉下来了”“每一个小群体都不该被放弃”…...
“购物成瘾”真的是一种病 刘艳 牛雅娟 本周日即将迎来“双十二”促销季,很多人又开始摩拳...
因迷恋山间风景,一男子在甘孜州稻城县海拔4000多米的无人区迷失方向,随后与同伴失联。12月的稻城...
嫌疑人DNA信息比中后,成都市公安局刑侦支队技术处DNA实验室民警白小刚一下坐在凳子上,恍惚迟疑间...
一批反映南京大屠杀历史的新书发布 新华社南京12月7日电(记者邱冰清、蒋芳)“以史为鉴,开创未来...
我在现场·照片背后的故事|电影《亲爱的》里面没有的结局,在我眼前“上映” 12月6日,在深圳市...
冥想?泡脚?不如听听助眠音乐 晚上睡不着,白天睡不醒,成为最贴合都市人群的“睡眠画像”。随...
养老话题 老年教育面临缺口 “终身教育”潜力无限 【现实挑战】“新老年”群体愿意在培养兴...
孙海洋被拐14年儿子如何找到的? 警方侦办另一宗拐骗儿童案时发现线索,通过人像比对、DNA确认找...
北京天文馆、圆明园将对未成年人免费开放 12月6日,北京天文馆发布通知称,12月8日起试行对未成...
今年全国粮食总产量再创新高 连续7年保持在1 3万亿斤以上 根据对全国31个省(区、市)的抽样调...
斑块软的很危险 硬的就无碍? 血管里的“垃圾”分类 赶快学起来! 一项最新研究显示:中国...
诺西那生钠注射液大幅降价 聚焦医保谈判背后脊髓性肌萎缩症家庭 医保目录公布那天 好多家长都...
抖音“窗花剪剪”遭抄袭 被判获赔20万元 法院认为“窗花剪剪”的这种表达方式理应受到《著作权...
公安机关近日侦破3起拐卖儿童案件 失散十几年 3组家庭终于团圆了 北京青年报记者12月6日从公...
2021年度十大网络用语发布 本报讯(记者 路艳霞)作为年度“汉语盘点”活动最具网络特色的组成部...
北京天文馆向未成年人免费开放 本报讯(记者 牛伟坤)北京天文馆对票价免费及优惠政策作出调整:1...
2021北京百个网红打卡地发布 本报讯(记者 李洋)2021北京网红打卡地推荐榜单昨晚正式发布。自然...