EffectiveJava-方法

/*
 * 38检查参数的有效性
 * 后果:1.处理失败、产生异常	2.正常返回、结果错误	3.正常返回、破坏某对象
 * 
 * 有些参数保存起来供以后使用,如:构造器
 * 
 * 39 必要时保护性拷贝
 * java是一门安全的语言,对于缓冲区溢出、数组越界、非法指针以及其它的内存破坏错误都自动免疫。
 * 参数的保护性拷贝并不仅仅针对不可变类。每当编写方法或者构造器时,如果它要允许客户提供的对象进入到内部数据结构中,则需要
 * 考虑客户提供的对象是否可变。若是,则考虑你的类在进入数据结构之后是否发生变化,若不能发生变化,则必须对对象进行保护性拷贝。
 * 并让拷贝之后的对象而不是原始对象进入到数据结构中。	
 * 
 * 40 谨慎设计方法签名
 * 缩短过长的参数列表:
 * 1.一个方法分解为多个方法,每个方法只需要这些参数的一个子集。
 * 2.创建辅助类,保存参数的分组。
 * 3.构造器采用Builder模式
 * 参数类型优先使用借口而不是类
 * */
public class Item38_40 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		long array[]={1,3,4};
		Item38_40.sort(null,4,1);
	}
	
	//断言
	public static void sort(long a[],int offset,int length){
		assert a != null;
		assert offset > 0 && offset<=a.length;
		assert length > 0 && length <= a.length-offset;	
	}
}

final class Period {
	final Date start;
	final Date end;
	public Period(Date start,Date end){
		if(start.compareTo(end) > 0 )
			throw new IllegalArgumentException(start + " after "+end);
		this.start=start;
		this.end = end;
	}
	public Date getStart(){
		return start;
	}
	public Date getEnd(){
		return end;
	}
	
	@Override
	public String toString() {
		return "Period [start=" + start + ", end=" + end + "]";
	}
	public static void main(String[] args) {
		Date start = new Date();
		Date end = new Date();
		Period p = new Period(start,end);
		System.out.println(p);
		start.setYear(2019);
		System.out.println(p);//p改变
	}
}
//进行保护性拷贝实验
final class Period1 {
	final Date start;
	final Date end;
	public Period1(Date start,Date end){
		this.start = new Date(start.getTime());//保护性拷贝
		this.end = new Date(end.getTime());	
		/*
		 * 后进行有效性检查 放在保护性拷贝之后
		 * 避免在“危险阶段”期间从另一个线程改变类的参数。
		 * */
		if(start.compareTo(end) > 0 )
			throw new IllegalArgumentException(start + " after "+end);
	}
	public Date getStart(){
		return new Date(start.getTime());//保护性拷贝
	}
	public Date getEnd(){
		return new Date(end.getTime());
	}
	
	@Override
	public String toString() {
		return "Period [start=" + start + ", end=" + end + "]";
	}
	public static void main(String[] args) {
		Date start = new Date();
		Date end = new Date();
		Period1 p = new Period1(start,end);
		System.out.println(p);
		p.getEnd().setHours(1);
		start.setYear(1);
		System.out.println(p);//不改变
	}
}
/*
 * 41 慎用重载
 * 重载--静态选择--编译时类型
 * 重写--动态选择--运行时类型
 * 
 * 对于重载方法的选择是静态的,对于重写方法的选择是动态的
 * 选择被重写的方法的正确版本是在运行时进行的,选择依据:被调用方法所在对象的运行时类型。
 * 当子类方法重写父类方法时,并且这个方法是在孩子类的实例上被调用,那么子类的重写方法将被执行,而不管其编译时类型。
 * 在进行重写时,对于某对象 某重写方法 执行最为具体的方法
 * 
 * 两个重载方法在同样的参数上被调用时,它们执行相同的功能,重载就不会带来危害。
 * 标准做法:在一般的方法中调用具体方法
 * 
 * 42 慎用可变参数 
 * 可变参数是用printf而设计
 * 
 * 43 返回零长度的数组或集合 而不是null
 * 否则在客户端要有非null判断
 * */
class AsList{
	public static void main(String[] args) {
		List<String> l = Arrays.asList("a","b","c");
		System.out.println(l);//[a, b, c]
		List<Integer> l1 = Arrays.asList(1,23,3);
		System.out.println(l1);//[1, 23, 3]
		
		//asList返回的List是Array中的实现的内部类
		Integer [] ii = {1,23,5};
		List<Integer> l2=Arrays.asList(ii);
		System.out.println(l2);//[1, 23, 5]
		ii[0]=0;
		l2.set(1, 0);
		System.out.println(Arrays.asList(l2));//[0, 0, 5]
		
		int [] ints = {132,32,342,32};
		System.out.println(Arrays.asList(ints));//[[I@2a139a55] 把ints当成一个元素
	}
}
public class Item41_43 {

	public static void main(String[] args) {
	
		Set<Integer> set = new TreeSet<Integer>();
		List<Integer> list = new ArrayList<Integer>();
		
		for(int i= -2;i<3;i++){
			set.add(i);
			list.add(i);
		}
		System.out.println(set);//[-2, -1, 0, 1, 2]
		System.out.println(list);//[-2, -1, 0, 1, 2]
		
		for(int i= 0;i<3;i++){
			set.remove(i);//remove(object)
			list.remove(i);//remove(int index) remove(object)
			
			//修改:list.remove((Integer)i);
		}
		System.out.println(set);//[-2, -1]
		System.out.println(list);//[-1, 1]

	}
	
}

class CollectionClassifer {
	public static void classify(Collection<?> c) {
		System.out.print("collection ");
	}

	public static void classify(Set<?> c) {
		System.out.print("set ");
	}

	public static void classify(List<?> c) {
		System.out.print("list ");
	}
	
	public static void classify1(Collection<?> c){
		System.out.println( c instanceof Set?"set":c instanceof List?"list":"others");
	}

	public static void main(String[] args) {
		Collection<?> [] c = {new HashSet<String>(),new ArrayList<String>(),new HashMap<String,String>().values()};
		
		for(Collection<?> l : c){
			classify(l);
			//classify1(l);
		}
		//输出:collection collection collection 
		/*
		 * 调用哪个重载方法是由编译时决定的,对于for循环你的三次迭代过程中,参数的编译时类型是相同的:Collection<?>,
		 * 每次迭代时的运行时类型都是不同的,但是并不影响对重载方法的选择。
		 * */
	}
}
class Wine{
	void name(){
		System.out.print("wine ");
	}
}
class Wine1 extends Wine{
	void name(){
		System.out.print("wine1 ");
	}
}
class Wine2 extends Wine1{
/*	void name(){
		System.out.print("wine2 ");
	}*/
	public static void main(String[] args) {
		Wine [] c = {new Wine(),new Wine1(),new Wine2()};
		
		for(Wine l : c){
			l.name();;
		}
		//输出:wine wine1 wine1   
		//执行最为具体的方法
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《Effective Java第三版》是由Joshua Bloch所著的一本Java编程指南。这本书是基于第二版的更新版本,目的是给Java程序员提供一些最佳实践和经验,以编写高效、可维护和可靠的Java代码。 这本书共分为15个章节,每个章节都讲解了一个与Java开发有关的重要主题。比如,章节一讲述了使用静态工厂方法代替构造器的优点,章节二则介绍了如何用Builder模式来构建复杂的对象。此外,书中还提及了Java对象的等价性、覆盖equals方法和hashCode方法、避免创建不必要的对象、使用泛型、枚举、lambda表达式等等。 《Effective Java第三版》通过具体的代码示例和清晰的解释来说明每个主题的关键概念,使读者能够更好地理解和应用。此外,书中还提供了一些实用的技巧和技术,例如避免使用原始类型、尽量使用接口而非类来定义类型等。 总的来说,这本书提供了很多实用的建议和技巧,可以帮助Java开发者写出高质量的代码。无论是初学者还是有经验的开发者,都可以从中受益匪浅。无论你是打算从头开始学习Java编程,还是已经有一定经验的开发者,这本书都是值得推荐的读物。 ### 回答2: 《Effective Java 第三版》是由Joshua Bloch 所著的一本Java编程指南,是Java程序员必读的经典之作。该书共包含90个条目,涵盖了各种Java编程的最佳实践和常见问题的解决方法。 本书分为多个部分,每个部分都侧重于一个特定的主题。作者探讨了Java编程中的各种问题和挑战,并提供了解决方案和建议。这些建议包括如何选择和使用合适的数据结构和算法,如何设计高效的类和接口,如何处理异常和错误,以及如何编写可读性强的代码等等。 《Effective Java 第三版》还关注了Java编程中的性能优化和安全性问题。作者强调了遵循Java语言规范、使用标准库、防范常见安全漏洞等重要原则。此外,本书还介绍了Java 8及其后续版本的新特性和用法,如Lambda表达式、流式编程和Optional类等。 这本书的特点之一是每个条目都独立于其他条目,可以单独阅读和理解。每个条目开头都有一个简洁的总结,让读者能够快速掌握主要观点。此外,书中还有大量的示例代码和解释,帮助读者更好地理解和运用所学知识。 总的来说,《Effective Java 第三版》是一本非常实用和全面的Java编程指南。它适用于各个层次的Java程序员,无论是初学者还是有经验的开发人员,都可以从中获得宝贵的经验和知识。无论是编写高质量的代码、优化性能还是确保安全性,这本书都是一本不可或缺的参考书籍。 ### 回答3: 《Effective Java 第3版(中文版)》是由 Joshua Bloch 所著的一本关于使用 Java 编程语言的指南书。该书是对 Java 语言的最佳实践的详尽描述,为中高级 Java 开发人员提供了许多实用的建议和技巧。 该书的主要内容包括Java 语言的优雅编程风格、类和接口的设计、Lambda 表达式和流的使用、泛型、异常和并发编程等方面的最佳实践。 在《Effective Java 第3版(中文版)》中,许多传统的 Java 开发中的陷阱、常见错误和不良习惯都得到了深入的剖析和解答。它不仅提供了可供开发人员参考的示例代码,还解释了为什么某种方式是有问题的,以及如何更好地进行改进。 该书的深度和广度非常适合正在努力提高 Java 编程技能的开发人员。它涵盖了多个关键领域,为读者提供了在实际项目中解决常见问题的方法和思路。 此外,《Effective Java 第3版(中文版)》还介绍了最新版本的一些特性和改进。例如,它详细说明了如何正确地使用 Java 8 中新增的 Lambda 表达式和流,以及如何充分利用 Java 9、10 和 11 中的新功能。 总之,这本书是 Java 开发人员必备的指南之一。通过深入理解和应用书中的实践建议,读者可以更加高效地编写、优化和维护 Java 代码。无论是想提升职业技能还是在项目中减少错误和问题,这本《Effective Java 第3版(中文版)》都是一本非常有帮助的参考书。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值