间歇性混吃等死,持续性踌躇满志系列-------------第4天

1、静态内部类求极值

 class MaxMin{
public static class Result{
//表示最大值、最小值
private double Max;
private double Min;
//使用构造方法进行初始化
public Result(double max,double min){
this.Max = max;
this.Min = min;
}
//获得最大值
public double getMax(){
return Max;
}
//获得最小值
public double getMin(){
return Min;
}
}
public static Result getResult(double[] array){
double max = Double.MIN_VALUE;
double min = Double.MAX_VALUE;
//遍历数组获得最大值和最小值
for(double i :array){
if(i>max){
max =i;
}
if(i<min){
min = i;
}
}
return new Result(max,min);
}
}
public class Test{
public static void main(String[] args){
double[] array = new double[4];
for(int i =0;i<array.length;i++){
//初始化数组
array[i] = 100*Math.random();
}
System.out.println("源数组:");
for(int i = 0;i<array.length;i++){
//显示数组中的各个元素
System.out.println(array[i]);
}
//显示最大值、最小值
System.out.println("最大值:"+MaxMin.getResult(array).getMax());
System.out.println("最小值:"+MaxMin.getResult(array).getMin());
}
}

运行结果图

2、利用反射重写toString()方法

 import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier; public class StringUtils{
@SuppressWarnings("unchecked")
public String toString(Object object){
//获得代表该类的class对象
Class clazz = object.getClass();
//利用StringBuilder来保存字符串
StringBuilder sb = new StringBuilder();
//获得类所在的包
Package packageName = clazz.getPackage();
//输出类所在的包
sb.append("包名:"+packageName.getName()+"\t");
//获得类的简单名称
String className = clazz.getSimpleName();
//输出类的简单名称
sb.append("类名:"+className+"\n");
sb.append("公共构造方法:\n");
//获得所有代表构造方法的Constructor数组
Constructor[] constructors = clazz.getDeclaredConstructors();
for(Constructor constructor:constructors){
//获得修饰符
String modifier = Modifier.toString(constructor.getModifiers());
//查看修饰符是否含有public
if(modifier.contains("public")){
sb.append(constructor.toGenericString()+"\n");
}
}
sb.append("公共域:\n");
//获得所有域的Field[]数组
Field[] fields = clazz.getDeclaredFields();
for(Field field:fields){
String modifier = Modifier.toString(field.getModifiers());
//查看修饰符是否含有public
if(modifier.contains("public")){
sb.append(field.toGenericString());
}
}
sb.append("公共方法:\n");
//获得代表所有方法的Method[]数组
Method[] methods = clazz.getDeclaredMethods();
for(Method method:methods){
String modifier = Modifier.toString(method.getModifiers());
//查看修饰符是否含有public
if(modifier.contains("public")){
sb.append(method.toGenericString()+"\n");
}
}
return sb.toString();
}
public static void main(String[] args){
System.out.println(new StringUtils().toString(new java.util.Date()));
}
}

利用反射重写toString()方法

运行结果图

3、创建集合对象

创建集合对象

运行结果图

4、Set接口的常用方法

set集合由set接口和set接口的实现类组成。由于set集合中不允许存在重复值,因此可以使用set集合中的addAll()方法,将collection集合添加到Set集合中并去重

 import javax.print.DocFlavor;
import java.util.*; public class CollectionDemo{
public static void main(String[] args){
//创建List集合对象
List<String> list = new ArrayList<String>();
//向集合中添加元素
list.add("apple");
list.add("pear");
list.add("banada");
list.add("apple");
//创建list集合对象
Set<String> set = new HashSet<String>();
//将list集合添加到set集合中
set.addAll(list);
//创建set集合迭代器
Iterator<String> it = set.iterator();
System.out.println("集合中的元素是:");
while (it.hasNext()){
System.out.println(it.next()+"\t");
}
}
}

运行结果图

5、求出1-100之间的偶数和

 public class Demo01{
public static void main(String[] args){
int sum = 0;
for(int i=0;i<=100;i+=2){
sum = sum+i;
}
System.out.println(sum);
}
}

运行结果图

JAVA进阶4的更多相关文章

  1. Java 进阶 hello world! - 中级程序员之路

    Java 进阶 hello world! - 中级程序员之路 Java是一种跨平台的语言,号称:"一次编写,到处运行",在世界编程语言排行榜中稳居第二名(TIOBE index). ...

  2. Java进阶(五)Java I/O模型从BIO到NIO和Reactor模式

    原创文章,同步发自作者个人博客,http://www.jasongj.com/java/nio_reactor/ Java I/O模型 同步 vs. 异步 同步I/O 每个请求必须逐个地被处理,一个请 ...

  3. Java线程间通信方式剖析——Java进阶(四)

    原创文章,同步发自作者个人博客,转载请在文章开头处以超链接注明出处 http://www.jasongj.com/java/thread_communication/ CountDownLatch C ...

  4. Java进阶(三)多线程开发关键技术

    原创文章,同步发自作者个人博客,转载请务必以超链接形式在文章开头处注明出处http://www.jasongj.com/java/multi_thread/. sleep和wait到底什么区别 其实这 ...

  5. 当我们说线程安全时,到底在说什么——Java进阶系列(二)

    原创文章,同步发自作者个人博客,转载请以超链接形式在文章开头处注明出处http://www.jasongj.com/java/thread_safe/ 多线程编程中的三个核心概念 原子性 这一点,跟数 ...

  6. Java进阶03 IO基础

    链接地址:http://www.cnblogs.com/vamei/archive/2013/04/11/3000905.html 作者:Vamei 出处:http://www.cnblogs.com ...

  7. Java进阶01 String类

    链接地址:http://www.cnblogs.com/vamei/archive/2013/04/08/3000914.html 作者:Vamei 出处:http://www.cnblogs.com ...

  8. 从ConcurrentHashMap的演进看Java多线程核心技术 Java进阶(六)

    本文分析了HashMap的实现原理,以及resize可能引起死循环和Fast-fail等线程不安全行为.同时结合源码从数据结构,寻址方式,同步方式,计算size等角度分析了JDK 1.7和JDK 1. ...

  9. Java进阶(七)正确理解Thread Local的原理与适用场景

    原创文章,始自发作者个人博客,转载请务必将下面这段话置于文章开头处(保留超链接). 本文转发自技术世界,原文链接 http://www.jasongj.com/java/threadlocal/ Th ...

  10. Java进阶(四十七)Socket通信

    Java进阶(四十七)Socket通信   今天讲解一个 Hello Word 级别的 Java Socket 通信的例子.具体通讯过程如下: 先启动Server端,进入一个死循环以便一直监听某端口是 ...

随机推荐

  1. centos7下kubernetes(13。kubernetes-探讨service IP)

    service cluster IP是一个虚拟IP,是由kubernetes节点上的iptables规则管理的 通过iptables-save | grep 10.105.215.156看到与clus ...

  2. Android开发中,使用 EditText 输入内容,如何进行一键清空内容处理

    本文仅为个人的处理方式,希望能对您有所帮助,欢迎各位留言指正,抱拳了 1.text.xml示例: <?xml version="1.0" encoding="utf ...

  3. C#中字节数组(byte[])和字符串相互转换

    转换过程主要使用到System.Text.Encoding命名空间下的类 1. 字符串转换成字节数组byte[]: string str = "This is test string&quo ...

  4. 小小知识点(六)——算法中的P问题、NP问题、NP完全问题和NP难问题

    转自CSDN默一鸣 https://blog.csdn.net/yimingsilence/article/details/80004032 在讨论算法的时候,常常会说到这个问题的求解是个P类问题,或 ...

  5. OpenStack-Nova(4)

    一. Nova概述 使用OpenStack Compute来托管和管理云计算系统.OpenStack Compute是基础架构即服务(IaaS)系统的主要部分.主要模块在Python中实现. Open ...

  6. SpringBoot返回date日期格式化,解决返回为TIMESTAMP时间戳格式或8小时时间差

    问题描述 在Spring Boot项目中,使用@RestController注解,返回的java对象中若含有date类型的属性,则默认输出为TIMESTAMP时间戳格式 ,如下所示: 解决方案    ...

  7. Eclipse 设置背景色

    window -> preferences ->  General -> Editors -> Test Editors -> Background color 勾掉Sy ...

  8. P1226 【模板】快速幂||取余运算

    https://www.luogu.org/problemnew/show/P1226 模板题 直接上代码吧 #include<bits/stdc++.h> using namespace ...

  9. jQuery初识之选择器、样式操作和筛选器(模态框和菜单示例)

    一.jQuery 1.介绍 jQuery是一个快速.简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架). jQuery设计的 ...

  10. 洛谷P1262间谍网络

    题目 我们首先考虑该题没有环应该怎么做,因为没有环所以是一个DAG,因此直接加上入度为0的罪犯,而有环则可以缩点,之后就成为了DAG,然后用一方法做就好了. \(Code\) #include < ...