《Java解惑》系列——02字符谜题--字符串谜题总结

2024-08-30 00:38

本文主要是介绍《Java解惑》系列——02字符谜题--字符串谜题总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

利用一周的时间,读完了字符串谜题。这一篇,主要讲在java编程中,字符串的一些常见陷阱和惯用法以及注意事项。

现在,总结如下:

1、字符的连接操作。'a'+'b',请注意,java字符的行为更像数字类型而不是字符串。short是整形的一个分支。

'a'+'b'结果不是ab而是一个int的数字,要想打印ab,则需要一些惯用法来解决:""+'a'+'b',这样才可以。

2、java中对char[]的重载:

1、sysout打印char[],因为其重载了该方法,所以打印char数组中的数字。

2、但是请注意这样的操作,sysout打印“abc”+char[]数组,虽然sysout重载了char[],但是没有重载字符串的加法。

具体规则详见:http://blog.csdn.net/wangsr4java/article/details/23993229

3、字符串在判断相等的时候最好使用equals,不要依赖jvm对:编译器常量的内存限定,这样,很容易引起错误和误解。

这个教训是:不使用不常用的编程技巧、不使用依赖编译器的技巧(这要求使用者得非常熟悉这些规则和技巧)

4、在sysout的时候,注意字符串连接符“+”与其他运算符的优先级;

5、接下来是Java中的转义字符:

1、Unicode转义字符:\u + 四个十六进制数字;0~65535 。

这个要非常的注意,应为jvm编译器会在将源代码转换成各种符号之前,将unicode编码转换为其对应的字符;

2、八进制转义字符:\ + 1到3位数字;范围'\000'~'\377'

3、普通转义字符:以反斜杠“\”开头

6、关于转义字符的经验教训:

1、不要使用unicode转义字符表示ANSII字符;

2、在字符和字符串字面常量中,优先使用:普通转义字符和八进制转义字符,不推荐使用unicode转义字符;

3、在JavaDoc中,不要使用Unicode转义字符,应该使用HTML转义字符替代;

4、在注释中,不要使用Unicode转义字符;

5、总结,Unicode是被设计用来在源代码文件编码无法显示的字符时才会使用Unicode转义字符,总之,不到玩不得用,不要使用Unicode转义字符。

7、注意构造函数:String(char[])

这个教训是,使用常用的API,在使用不熟悉的API的时候,我们一定要谨慎。

8、要注释块代码请使用单行注释,不要使用/**/,块注释不能可靠的注释掉代码块

9、String的replaceAll方法的使用,一定要注意“正则”和“\”和“$”。

详见:http://blog.csdn.net/wangsr4java/article/details/24419377

10、令人误解的注释,往往引起错误。

还有就是如果某些东西看起来过于奇怪,以至于不像对的,那么它极有可能就是错的

11、常见的陷阱:

详见:http://blog.csdn.net/wangsr4java/article/details/24451405

这篇关于《Java解惑》系列——02字符谜题--字符串谜题总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1119307

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;