-
public可在任意位置访问,private仅限声明类内部使用,protected允许同包内所有类或不同包的子类自身实例访问(不可通过父类引用调用),默认修饰符仅限同包访问。
-
Scanner.nextLine()读不到输入是因为前序的nextInt()等方法未消费换行符,导致nextLine()立即读取空字符串;应在其后加scanner.nextLine()清缓存,或统一用nextLine()配合parseXXX转型。
-
使用File类可基础遍历目录,通过listFiles()获取子项并判断类型输出;2.推荐使用NIO.2的Files.list()或Files.walk()结合Stream实现高效、安全的目录浏览,支持流式处理与异常管理。
-
JavaPattern/Matcher在处理含Unicode字符(如℃、Ω)的字符串时,若正则表达式未正确覆盖目标字符大小写或编码语义,会导致find()误判成功但group()返回空或null,且start()位置偏移——根本原因常是正则逻辑缺陷,而非Unicode编码问题。
-
removeIf方法通过传入Predicate实现条件删除,如删除偶数或年龄小于18的用户,需注意集合可变性、线程安全及原集合被修改的问题。
-
通过封装、多态和职责分离将业务逻辑与代码结构对齐,用领域对象替代贫血模型,以Order.pay()为例实现内聚校验,利用DiscountStrategy多态消除条件分支,拆分大Service为小聚合如UserRegistration,通过方法名validateEligibilityForPromotion等表达业务意图,使代码具备可读性与扩展性。
-
Java反射是JVM提供的标准能力,通过Class对象动态获取类型信息并调用成员,但存在性能开销与安全限制;获取Class有三种方式,访问成员需区分getDeclaredXXX与getXXX,invoke()调用有三处易错点,且反射影响JIT优化。
-
答案:Java中通过staticfinal声明类常量,final声明局部常量,命名全大写加下划线,提高可读性、便于维护、避免魔法数字,注意必须初始化且引用类型仅地址不可变。
-
Arrays.binarySearch搜不到明明存在的元素是因为它仅对已排序数组有效;未排序或降序数组(未配对应Comparator)会导致结果不可靠,返回负数表示插入点编码而非简单“未找到”。
-
ScheduledThreadPoolExecutor不能替代synchronized,因其仅负责任务调度,不提供线程安全;并发问题需靠任务内部同步机制(如锁、ConcurrentHashMap)解决,而非调度时机。
-
TreeMap默认按键的自然顺序排序,要求键实现Comparable接口。使用String或自定义类(如Person)作为键时,只要实现compareTo()方法,插入后遍历即为有序结果,且键不能为null。
-
使用ViewCompat.setOnApplyWindowInsetsListener监听软键盘高度时,若直接返回原始insets会导致状态栏背景色丢失;正确做法是调用ViewCompat.onApplyWindowInsets(v,insets)将insets交由系统默认处理,既保留状态栏/导航栏样式,又确保自定义逻辑生效。
-
明确异常类型并分层记录日志,使用自定义异常和异常链保留上下文,在全局处理器中统一记录ERROR日志,避免吞异常或重复打印,确保问题可追溯。
-
首先确保安装JDK并配置环境变量,然后从Apache官网下载NetBeans安装包并按向导安装,启动后检查JDK注册、设置项目路径与插件,最后创建Java项目运行HelloWorld验证配置成功。
-
getItems()返回原始引用导致内部状态被篡改,因Java集合默认不拷贝、final仅锁引用不锁内容;安全做法是返回不可变视图或独立副本。