为什么System.out.println();不报控制针异常

本文探讨了Java中静态导入的特性及其与反射技术的关系。通过示例解释了即使被final static修饰的对象为空也不会抛出空指针异常的原因,并展示了如何使用反射技术修改final static变量。

为什么突然间想到这个呢,是因为看到jdk1.5 的静态导入

package newFeatures5;
import static java.lang.System.out;//静态导入
public class staticImport {
	public static void main(String[] args) {
		out.println();
	}
}

不好奇不知道,一好奇吓一跳,Ctrl+鼠标左键一下,天啊这个out对象是null


问题来了,既然out对象为空 而且被 final static 修饰,为什么 System.out.println();不报空指针异常(NullPointerException)呢?








然而为什么不会能,很大可能性是因为反射技术,因为反射技术可以修改被定义为final、static、或是final static的字段

package newFeatures8;
import static java.lang.System.out;

import java.lang.reflect.Field;
import java.lang.reflect.Modifier;
public class BubbleSort {
	public static void main(String[] args) throws Exception {
		Person1.main(args);
	}
}


 class Person1 {
    public static void main(String[] args) throws Exception {
      /*  Person1 p = new Person1();
        Field field = p.getClass().getDeclaredField("NAME");
        field.setAccessible(true);
        field.set(p,"Hello");
        System.out.println(field.get(p));
        p.printName();*/
    	
    	 Person1 p = new Person1();
         Field field = p.getClass().getDeclaredField("NAME");
        
         Field modifiers = field.getClass().getDeclaredField("modifiers");
         /*Field[] fields= field.getClass().getDeclaredFields();
         for (Field field2 : fields) {
			System.out.println(field2.getName());
		}*/
         modifiers.setAccessible(true);
         modifiers.setInt(field, field.getModifiers() & ~Modifier.FINAL);//fianl标志位置0
         field.set(p,"Hello");
         System.out.println(field.get(p));
         p.printName();
        
         
    }


   
    
    //private final  String NAME="Clive";
    private final static String NAME=(null!=null?"0":"Clive");
    public  Person1() {}//构造函数优先于成员变量,而静态变量又优先于构造函数

    public  void printName() {
        System.out.println(NAME);
    }
}
 
  
详情参考:http://www.cnblogs.com/fudashi/archive/2017/03/26/6624379.html


### 如何在 Java 中用 `forEach` 配合 `System.out::println` 输出集合元素 在 Java 中,可以通过 `forEach` 方法来迭代集合中的每一个元素,并结合方法引用 (`System.out::println`) 来实现简单快捷的输出功能。以下是具体说明: #### 代码示例 下面是一个完整的代码片段,展示了如何利用 `forEach` 和 `System.out::println` 打印集合中的所有元素。 ```java import java.util.ArrayList; import java.util.List; public class PrintCollection { public static void main(String[] args) { // 创建并初始化一个 List 集合 List<String> names = new ArrayList<>(); names.add("Alice"); names.add("Bob"); names.add("Charlie"); // 使用 forEach 结合 System.out::println 输出集合中的每个元素 names.forEach(System.out::println); } } ``` 这段代码创建了一个包含三个字符串的 `List` 集合,并通过调用其 `forEach` 方法逐一访问其中的每个元素[^1]。这里的方法引用 `System.out::println` 是一种简洁的方式,用于替代传统的 lambda 表达式写法 `(name -> System.out.println(name))`[^4]。 #### 工作原理 - **`forEach` 方法**:这是 Java 8 引入的一个默认方法,默认实现在接口 `Iterable` 中定义。它可以接受一个函数作为参数,在每次迭代时执行该函数。 - **方法引用**:`System.out::println` 是一种简化形式,表示调用静态方法 `System.out.println(Object)`。这种方法引用可以直接传递给 `forEach` 方法,从而减少冗余代码[^3]。 #### 注意事项 当使用 `forEach` 和 `System.out::println` 组合时需要注意以下几点: - 如果集合为空,则不会有任何输出,也不会抛出异常[^2]。 - 对于复杂的逻辑(如条件过滤),可以在 `forEach` 的 Lambda 表达式中加入更多控制语句,而不是单纯依赖 `System.out::println`。 ---
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值