java中驼峰命名和下划线命名互转方法(代码实现)

简介: 1 /** 2 * 将驼峰式命名的字符串转换为下划线大写方式。如果转换前的驼峰式命名的字符串为空,则返回空字符串。 3 * 例如:HelloWorld->HELLO_WORLD 4 * @param name 转换前的驼峰式命名的字符串 5 * @return 转换后下划线大写方...
 1 /**
 2  * 将驼峰式命名的字符串转换为下划线大写方式。如果转换前的驼峰式命名的字符串为空,则返回空字符串。
 3  * 例如:HelloWorld->HELLO_WORLD
 4  * @param name 转换前的驼峰式命名的字符串
 5  * @return 转换后下划线大写方式命名的字符串
 6  */
 7 public static String underscoreName(String name) {
 8     StringBuilder result = new StringBuilder();
 9     if (name != null && name.length() > 0) {
10         // 将第一个字符处理成大写
11         result.append(name.substring(0, 1).toUpperCase());
12         // 循环处理其余字符
13         for (int i = 1; i < name.length(); i++) {
14             String s = name.substring(i, i + 1);
15             // 在大写字母前添加下划线
16             if (s.equals(s.toUpperCase()) && !Character.isDigit(s.charAt(0))) {
17                 result.append("_");
18             }
19             // 其他字符直接转成大写
20             result.append(s.toUpperCase());
21         }
22     }
23     return result.toString();
24 }
 1 /**
 2  * 将下划线大写方式命名的字符串转换为驼峰式。如果转换前的下划线大写方式命名的字符串为空,则返回空字符串。
 3  * 例如:HELLO_WORLD->HelloWorld
 4  * @param name 转换前的下划线大写方式命名的字符串
 5  * @return 转换后的驼峰式命名的字符串
 6  */
 7 public static String camelName(String name) {
 8     StringBuilder result = new StringBuilder();
 9     // 快速检查
10     if (name == null || name.isEmpty()) {
11         // 没必要转换
12         return "";
13     } else if (!name.contains("_")) {
14         // 不含下划线,仅将首字母小写
15         return name.substring(0, 1).toLowerCase() + name.substring(1);
16     }
17     // 用下划线将原始字符串分割
18     String camels[] = name.split("_");
19     for (String camel :  camels) {
20         // 跳过原始字符串中开头、结尾的下换线或双重下划线
21         if (camel.isEmpty()) {
22             continue;
23         }
24         // 处理真正的驼峰片段
25         if (result.length() == 0) {
26             // 第一个驼峰片段,全部字母都小写
27             result.append(camel.toLowerCase());
28         } else {
29             // 其他的驼峰片段,首字母大写
30             result.append(camel.substring(0, 1).toUpperCase());
31             result.append(camel.substring(1).toLowerCase());
32         }
33     }
34     return result.toString();
35 }

 参考博客:http://jhonnnnnn.iteye.com/blog/2261298

我的GitHub地址: https://github.com/heizemingjun
我的博客园地址: http://www.cnblogs.com/chenmingjun
我的蚂蚁笔记博客地址: http://blog.leanote.com/chenmingjun
Copyright ©2018 黑泽明军
【转载文章务必保留出处和署名,谢谢!】
相关文章
|
4天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
|
18天前
|
XML 安全 Java
Java反射机制:解锁代码的无限可能
Java 反射(Reflection)是Java 的特征之一,它允许程序在运行时动态地访问和操作类的信息,包括类的属性、方法和构造函数。 反射机制能够使程序具备更大的灵活性和扩展性
33 5
Java反射机制:解锁代码的无限可能
|
10天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
50 4
|
21天前
|
Java API
Java 对象释放与 finalize 方法
关于 Java 对象释放的疑惑解答,以及 finalize 方法的相关知识。
42 17
|
15天前
|
jenkins Java 测试技术
如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例详细说明
本文介绍了如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例,详细说明了从 Jenkins 安装配置到自动构建、测试和部署的全流程。文中还提供了一个 Jenkinsfile 示例,并分享了实践经验,强调了版本控制、自动化测试等关键点的重要性。
47 3
|
20天前
|
存储 安全 Java
系统安全架构的深度解析与实践:Java代码实现
【11月更文挑战第1天】系统安全架构是保护信息系统免受各种威胁和攻击的关键。作为系统架构师,设计一套完善的系统安全架构不仅需要对各种安全威胁有深入理解,还需要熟练掌握各种安全技术和工具。
57 10
|
15天前
|
Java 测试技术 Maven
Java一分钟之-PowerMock:静态方法与私有方法测试
通过本文的详细介绍,您可以使用PowerMock轻松地测试Java代码中的静态方法和私有方法。PowerMock通过扩展Mockito,提供了强大的功能,帮助开发者在复杂的测试场景中保持高效和准确的单元测试。希望本文对您的Java单元测试有所帮助。
29 2
|
16天前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
14天前
|
Java
Java代码解释++i和i++的五个主要区别
本文介绍了前缀递增(++i)和后缀递增(i++)的区别。两者在独立语句中无差异,但在赋值表达式中,i++ 返回原值,++i 返回新值;在复杂表达式中计算顺序不同;在循环中虽结果相同但使用方式有别。最后通过 `Counter` 类模拟了两者的内部实现原理。
Java代码解释++i和i++的五个主要区别
|
16天前
|
Java Spring
JAVA获取重定向地址URL的两种方法
【10月更文挑战第17天】本文介绍了两种在Java中获取HTTP响应头中的Location字段的方法:一种是使用HttpURLConnection,另一种是使用Spring的RestTemplate。通过设置连接超时和禁用自动重定向,确保请求按预期执行。此外,还提供了一个自定义的`NoRedirectSimpleClientHttpRequestFactory`类,用于禁用RestTemplate的自动重定向功能。