博客地址:https://blog.csdn.net/houjiyu...
本系列文章將主要針對JAVA一些基礎知識點進行講解,爲平時概括所總結,無論是剛接觸JAVA開發菜鳥仍是業界資深人士,都但願對廣大同行帶來一些幫助。如有問題請及時留言或加QQ:243042162。html
寄語:
每一個人都有潛在的能量,只不過很容易被習慣掩蓋,被時間迷離,被惰性所消磨。
public class JDK8_features { public List<Integer> list = Lists.newArrayList(1,2,3,4,5,6,7,8,9,10); /** * 1.Lambda表達式 */ @Test public void testLambda(){ list.forEach(System.out::println); list.forEach(e -> System.out.println("方式二:"+e)); } }
/** * 2.Stream函數式操做流元素集合 */ @Test public void testStream(){ List<Integer> nums = Lists.newArrayList(1,1,null,2,3,4,null,5,6,7,8,9,10); System.out.println("求和:"+nums .stream()//轉成Stream .filter(team -> team!=null)//過濾 .distinct()//去重 .mapToInt(num->num*2)//map操做 .skip(2)//跳過前2個元素 .limit(4)//限制取前4個元素 .peek(System.out::println)//流式處理對象函數 .sum());// }
/** * 3.接口新增:默認方法與靜態方法 * default 接口默認實現方法是爲了讓集合類默認實現這些函數式處理,而不用修改現有代碼 * (List繼承於Iterable<T>,接口默認方法沒必要須實現default forEach方法) */ @Test public void testDefaultFunctionInterface(){ //能夠直接使用接口名.靜態方法來訪問接口中的靜態方法 JDK8Interface1.staticMethod(); //接口中的默認方法必須經過它的實現類來調用 new JDK8InterfaceImpl1().defaultMethod(); //多實現類,默認方法重名時必須複寫 new JDK8InterfaceImpl2().defaultMethod(); } public class JDK8InterfaceImpl1 implements JDK8Interface1 { //實現接口後,由於默認方法不是抽象方法,重寫/不重寫都成! // @Override // public void defaultMethod(){ // System.out.println("接口中的默認方法"); // } } public class JDK8InterfaceImpl2 implements JDK8Interface1,JDK8Interface2 { //實現接口後,默認方法名相同,必須複寫默認方法 @Override public void defaultMethod() { //接口的 JDK8Interface1.super.defaultMethod(); System.out.println("實現類複寫重名默認方法!!!!"); } }
@Test public void testMethodReference(){ //構造器引用。語法是Class::new,或者更通常的Class< T >::new,要求構造器方法是沒有參數; final Car car = Car.create( Car::new ); final List< Car > cars = Arrays.asList( car ); //靜態方法引用。語法是Class::static_method,要求接受一個Class類型的參數; cars.forEach( Car::collide ); //任意對象的方法引用。它的語法是Class::method。無參,全部元素調用; cars.forEach( Car::repair ); //特定對象的方法引用,它的語法是instance::method。有參,在某個對象上調用方法,將列表元素做爲參數傳入; final Car police = Car.create( Car::new ); cars.forEach( police::follow ); } public static class Car { public static Car create( final Supplier< Car > supplier ) { return supplier.get(); } public static void collide( final Car car ) { System.out.println( "靜態方法引用 " + car.toString() ); } public void repair() { System.out.println( "任意對象的方法引用 " + this.toString() ); } public void follow( final Car car ) { System.out.println( "特定對象的方法引用 " + car.toString() ); } }
@Test public void RepeatingAnnotations(){ RepeatingAnnotations.main(null); }
@Test public void ElementType(){ Annotations.main(null); }
@Test public void DateTime(){ //1.Clock final Clock clock = Clock.systemUTC(); System.out.println( clock.instant() ); System.out.println( clock.millis() ); //2. ISO-8601格式且無時區信息的日期部分 final LocalDate date = LocalDate.now(); final LocalDate dateFromClock = LocalDate.now( clock ); System.out.println( date ); System.out.println( dateFromClock ); // ISO-8601格式且無時區信息的時間部分 final LocalTime time = LocalTime.now(); final LocalTime timeFromClock = LocalTime.now( clock ); System.out.println( time ); System.out.println( timeFromClock ); // 3.ISO-8601格式無時區信息的日期與時間 final LocalDateTime datetime = LocalDateTime.now(); final LocalDateTime datetimeFromClock = LocalDateTime.now( clock ); System.out.println( datetime ); System.out.println( datetimeFromClock ); // 4.特定時區的日期/時間, final ZonedDateTime zonedDatetime = ZonedDateTime.now(); final ZonedDateTime zonedDatetimeFromClock = ZonedDateTime.now( clock ); final ZonedDateTime zonedDatetimeFromZone = ZonedDateTime.now( ZoneId.of( "America/Los_Angeles" ) ); System.out.println( zonedDatetime ); System.out.println( zonedDatetimeFromClock ); System.out.println( zonedDatetimeFromZone ); //5.在秒與納秒級別上的一段時間 final LocalDateTime from = LocalDateTime.of( 2014, Month.APRIL, 16, 0, 0, 0 ); final LocalDateTime to = LocalDateTime.of( 2015, Month.APRIL, 16, 23, 59, 59 ); final Duration duration = Duration.between( from, to ); System.out.println( "Duration in days: " + duration.toDays() ); System.out.println( "Duration in hours: " + duration.toHours() ); }
@Test public void testBase64(){ final String text = "就是要測試加解密!!abjdkhdkuasu!!@@@@"; String encoded = Base64.getEncoder() .encodeToString( text.getBytes( StandardCharsets.UTF_8 ) ); System.out.println("加密後="+ encoded ); final String decoded = new String( Base64.getDecoder().decode( encoded ), StandardCharsets.UTF_8 ); System.out.println( "解密後="+decoded ); }
@Test public void testParallel(){ long[] arrayOfLong = new long [ 20000 ]; //1.給數組隨機賦值 Arrays.parallelSetAll( arrayOfLong, index -> ThreadLocalRandom.current().nextInt( 1000000 ) ); //2.打印出前10個元素 Arrays.stream( arrayOfLong ).limit( 10 ).forEach( i -> System.out.print( i + " " ) ); System.out.println(); //3.數組排序 Arrays.parallelSort( arrayOfLong ); //4.打印排序後的前10個元素 Arrays.stream( arrayOfLong ).limit( 10 ).forEach( i -> System.out.print( i + " " ) ); System.out.println(); }
@Test public void testMetaspace(){ //-XX:MetaspaceSize初始空間大小,達到該值就會觸發垃圾收集進行類型卸載,同時GC會對該值進行調整 //-XX:MaxMetaspaceSize最大空間,默認是沒有限制 //-XX:MinMetaspaceFreeRatio在GC以後,最小的Metaspace剩餘空間容量的百分比,減小爲分配空間所致使的垃圾收集 //-XX:MaxMetaspaceFreeRatio在GC以後,最大的Metaspace剩餘空間容量的百分比,減小爲釋放空間所致使的垃圾收集 }
參考網站:
(1)https://www.cnblogs.com/suger...
(2)https://blog.csdn.net/xuspcsd...數組