什么样的类应该定义为final?类似LocalDateTime

以下是个人总结出常用,常见的:

在五个不同的包中:

  1. java.lang包中

    包装类:Boolean,Character,Short,Integer,Long,Float,Double,Byte,Void(八大类型的包装类型加一个void)

    字符串类:String,StringBuilder,StringBuffer

    系统类:System,Math,StrictMath


    其他:Character,UnicodeBlock,ProcessBuilder,StackTraceElement
  2. java.util包

    UUID,Scanner,Optional
  3. java.lang.reflect包

    Array,Constructor,Field,Parameter,ReflectPermission
  4. java.net包

    HttpCookie,URL,URI
  5. java.time包

除了Clock,ZoneId之外都是,如Year,YearMonth,MonthDay等

注意:其中标红的是最常见的.
 

Java中,final关键字可以用来修饰类、方法和变量(包括成员变量和局部bai变量)。下面就从这三个方面来了解一下final关键字的基本用法。
  1.修饰类
  当用final修饰一个类时,表明这个类不能被继承。也就是说,如果一个类你永远不会让他被继承,就可以用final进行修饰。final类中的成员变量可以根据需要设为final,但是要注意final类中的所有成员方法都会被隐式地指定为final方法
  在使用final修饰类的时候,要注意谨慎选择,除非这个类真的在以后不会用来继承或者出于安全的考虑,尽量不要将类设计为final类。
  2.修饰方法
  下面这段话摘自《Java编程思想》第四版第143页:
  “使用final方法的原因有两个。第一个原因是把方法锁定,以防任何继承类修改它的含义;第二个原因是效率。在早期的Java实现版本中,会将final方法转为内嵌调用。但是如果方法过于庞大,可能看不到内嵌调用带来的任何性能提升。在最近的Java版本中,不需要使用final方法进行这些优化了。“
  因此,如果只有在想明确禁止 该方法在子类中被覆盖的情况下才将方法设置为final的。
  注:类的private方法会隐式地被指定为final方法。
        类不是final,但是某些方法是final的,例如:
        还有???????????????????

  3.修饰变量
  修饰变量是final用得最多的地方,也是本文接下来要重点阐述的内容。首先了解一下final变量的基本语法:
  对于一个final变量,如果是基本数据类型的变量,则其数值一旦在初始化之后便不能更改;如果是引用类型的变量,则在对其初始化之后便不能再让其指向另一个对象。
       类不是final,但是变量是final的,例如:还有???????????????????

      

如何设计一个对象的方法

以及对象中方法之间的调用还有字段

public class Server {
	private int prot = 8080;
	public static void main(String[] args) {
		
	}
			
	private Selector getSelector() throws IOException {
		Selector sel = Selector.open();
		
		ServerSocketChannel server = ServerSocketChannel.open();
		server.configureBlocking(false);
		
		ServerSocket socket = server.socket();
		InetSocketAddress address = new InetSocketAddress(prot);
		socket.bind(address);
		
		server.register(sel, SelectionKey.OP_CONNECT);
		return sel;
	}
	
	public void listen() {
		
		System.out.println("listen on " + prot);
		try{
			while(true) {
				Selector selector = getSelector();
				selector.select();
				Set<SelectionKey> keys = selector.selectedKeys();
				Iterator<SelectionKey> iter = keys.iterator();
				while(iter.hasNext()) {
					SelectionKey key = iter.next();
					iter.remove();
					process(key);
				}
			}
		}catch(Exception e) {
			e.printStackTrace();
		}
	}
	
	public void process(SelectionKey key) {
		
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值