java.lang.Math 类包含用于执行基本数学运算的方法,如初等指数、对数、平方根和三角函数。类似这样的工具类,其所有方法均为静态方法,并且不会创建对象,调用起来非常简单。
// 静态常量
public static final double PI = 3.14159265358979323846;
// 返回参数的绝对值
public static int abs(int a)
System.out.println(Math.abs(-10)); // 10
// 按照四舍五入返回最接近参数的int类型
// 参数为float类型 返回值为int类型
public static int round(float a)
// 参数为double类型 返回值为long类型
public static long round(double a)
System.out.println(Math.round(3.14f)); // 3
System.out.println(Math.round(3.5)); // 4
// 向上取整, 返回double类型
public static double ceil(double a)
System.out.println(Math.ceil(10.1)); // 11.0
System.out.println(Math.ceil(-10.9)); // -10.0
// 向下取整, 返回double类型
public static double floor(double a)
System.out.println(Math.floor(10.9)); // 10.0
System.out.println(Math.floor(-10.1)); // -11.0
// 返回两个数的最大值, 参数可以是浮点型 或 整型
public static int max(int a, int b)
System.out.println(Math.max(10, 20)); // 20
// 返回两个数的最小值, 参数可以是浮点型 或 整型
public static int min(int a, int b)
System.out.println(Math.min(10, 20)); // 10
// 返回 a的b次幂
public static double pow(double a, double b)
System.out.println(Math.pow(3, 5)); // 243.0
// 返回随机小数[0-1), 该方法调用了java.util.Random类
public static double random()
System.out.println(Math.random()); // 0.20964406221200327
// 1-100的随机整数
System.out.println(Math.floor(Math.random() * 100) + 1);
java.math.BigInteger类,不可变的任意精度的整数。如果运算中,数据的范围超过了long类型后,可以使用BigInteger类实现,该类的计算整数是不限制长度的。
// 构造方法
// 超过long类型的范围,已经不能称为数字了,因此构造方法中采用字符串的形式来表示超大整数,将超大整数封装成BigInteger对象。
public BigInteger(String val)
BigInteger b1 = new BigInteger("123213124124543123");
BigInteger b2 = new BigInteger("123213124124543123");
// 返回其值为 (this + val) 的 BigInteger,超大整数加法运算
public BigInteger add(BigInteger val)
System.out.println(b1.add(b2));
// 246426248249086246
// 返回其值为 (this - val) 的 BigInteger,超大整数加法运算
public BigInteger subtract(BigInteger val)
System.out.println(b1.subtract(b2));
// 0
// 返回其值为 (this * val) 的 BigInteger,超大整数加法运算
public BigInteger multiply(BigInteger val)
System.out.println(b1.multiply(b2));
// 15181473956530070530603493486593129
// 返回其值为 (this / val) 的 BigInteger,超大整数加法运算
public BigInteger divide(BigInteger val)
System.out.println(b1.divide(b2));
// 1
java.math.BigDecimal类,不可变的、任意精度的有符号十进制数。该类可以实现超大浮点数据的精确运算。
// 构造方法
public BigDecimal(String val)
BigDecimal bd1 = new BigDecimal("0.01");
BigDecimal bd2 = new BigDecimal("0.05");
BigDecimal的 加减乘 方法与BigInteger相同, 除法在可以除尽的情况下可以使用
若除不尽时 无法得到一个精确的小数 会报错, 需要传入额外的参数
// add 加法
System.out.println(bd1.add(bd2)); // 0.06
// subtract 减法
System.out.println(bd1.subtract(bd2)); // -0.04
// multiply 乘法
System.out.println(bd1.multiply(bd2)); // 0.0005
public BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
// BigDecimal divesor:此 BigDecimal 要除以的值
// int scale 保留几位小数
// int roundingMode 模式:(常用)
// BigDecimal.ROUND_HALF_UP 四舍五入
// BigDecimal.ROUND_UP 向上取整
// BigDecimal.ROUND_DOWN 向下取整
System.out.println(bd1.divide(bd2,2,BigDecimal.ROUND_HALF_UP));
// 0.20
Java提供了两个类型系统,基本类型与引用类型,使用基本类型在于效率,然而很多情况,会创建对象使用,因为对象可以做更多的功能,如果想要我们的基本类型像对象一样操作,就可以使用基本类型对应的包装类,如下:
| 基本类型 | 对应的包装类(位于java.lang包中) |
|---|---|
| byte | Byte |
| short | Short |
| int | Integer |
| long | Long |
| float | Float |
| double | Double |
| char | Character |
| boolean | Boolean |
// 返回表示指定的 int 值的 Integer 实例
public static Integer valueOf(int i)
// 返回表示指定的 String 值的 Integer 实例
public static Integer valueOf(String s)
Integer i1 = Integer.valueOf(100);
System.out.println(i1); // 100
Integer i2 = Integer.valueOf("100");
System.out.println(i2); // 100
基本类型与对应的包装类对象之间,来回转换的过程称为”装箱“与”拆箱“:
基本数值 --> 包装对象
Integer i = new Integer(4);//使用构造函数函数
Integer ii = Integer.valueOf(4);//使用包装类中的valueOf方法
包装对象 --> 基本数值
int num = i.intValue();
由于经常要做基本类型与包装类之间的转换,从Java 5(JDK 1.5)开始,基本类型与包装类的装箱、拆箱动作可以自动完成。
Integer i = 4; //自动装箱。相当于Integer i = Integer.valueOf(4);
i = i + 5; //等号右边:将i对象转成基本数值(自动拆箱) i.intValue() + 5;
//加法运算完成后,再次装箱,把基本数值转成对象。
public static void main(String[] args) {
//int --- String
//方式1
String s1 = 10 + "";
System.out.println(s1);
//方式2
//public static String valueOf(int i)
String s2 = String.valueOf(10);
System.out.println(s2);
}
除了Character类之外,其他所有包装类都具有parseXxx的静态方法,可以将字符串参数转换为对应的基本类型:
// 将字符串参数转换为对应的int基本类型。
public static int parseInt(String s)
// 将字符串参数转换为对应的double基本类型。
public static double parseDouble(String s)
// 字符串参数转换为对应的boolean基本类型。
public static boolean parseBoolean(String s)
// 字符串参数转换为char基本类型,使用String类中的charAt方法
public char charAt(int index)
// String -> int
System.out.println(Integer.parseInt("10"));
// String -> doubel
System.out.println(Double.parseDouble("10.21"));
// String -> boolean
System.out.println(Boolean.parseBoolean("true"));
// String -> char
System.out.println("a".charAt(0));
// 构造方法
public static int compare(int x, int y)
// x > y 返回 1
// x = y 返回 0
// x < y 返回 -1
System.out.println(Integer.compare(20, 20));
System.out.println(Double.compare(20.3, 20.1));
正则表达式(regular expression)是对字符串操作的一种规则, 用来做字符串匹配
| 规则写法 | 规则含义 |
|---|---|
| [abc] | a、b 或 c(简单类) |
| [^abc] | 任何字符,除了 a、b 或 c(否定) |
| [a-zA-Z] | a 到 z 或 A到 Z,两头的字母包括在内(范围) |
| [0-9] | 0到9,两头的数字包括在内(范围) |
| [a-zA-Z0-9] | a 到 z 或 A到 Z或0-9 |
| 规则写法 | 规则含义 |
|---|---|
| . | 任何字符 |
| \d | 数字[0-9] |
| \D | 非数字 [^0-9] |
| \w | 单词字符 [a-zA-Z0-9_] |
| \W | 非单词字符[^a-zA-Z0-9_] |
{n} 匹配n次
{n,} 匹配n次或多次
{n,m}匹配n次到m次
public boolean matches(String regex)
// 将字符串与传入的正则表达式进行匹配, 返回布尔值
public static void main(String[] args){
//验证手机号码
String tel = "13912345678";
String telRegex = "1[345678][0-9]{9}";
boolean flag = tel.matches(telRegex);
System.out.println(flag);
//验证邮件地址
String email = "h_123123@163.com.cn.";
String emailRegex = "[a-zA-Z0-9_]+@([a-z]+\\.[a-z]+)+";
flag = email.matches(emailRegex);
System.out.println(flag);
}
String[] split(String regex)
// 传递正则表达式规则,以正则规则对字符串进行切割
String str1 = "ab a bbb abc aa c";
// String[] strArr =str1.split(" +");
String[] strArr =str1.split("\\s+");
System.out.println(Arrays.toString(strArr));
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
下面例子中的Nested和Child有什么区别?是否只是同一事物的不同语法?classParentclassNested...endendclassChild 最佳答案 不,它们是不同的。嵌套:Computer之外的“Processor”类只能作为Computer::Processor访问。嵌套为内部类(namespace)提供上下文。对于ruby解释器Computer和Computer::Processor只是两个独立的类。classComputerclassProcessor#Tocreateanobjectforthisc
只是想确保我理解了事情。据我目前收集到的信息,Cucumber只是一个“包装器”,或者是一种通过将事物分类为功能和步骤来组织测试的好方法,其中实际的单元测试处于步骤阶段。它允许您根据事物的工作方式组织您的测试。对吗? 最佳答案 有点。它是一种组织测试的方式,但不仅如此。它的行为就像最初的Rails集成测试一样,但更易于使用。这里最大的好处是您的session在整个Scenario中保持透明。关于Cucumber的另一件事是您(应该)从使用您的代码的浏览器或客户端的角度进行测试。如果您愿意,您可以使用步骤来构建对象和设置状态,但通常您
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/
HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候
遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg
我基本上来自Java背景并且努力理解Ruby中的模运算。(5%3)(-5%3)(5%-3)(-5%-3)Java中的上述操作产生,2个-22个-2但在Ruby中,相同的表达式会产生21个-1-2.Ruby在逻辑上有多擅长这个?模块操作在Ruby中是如何实现的?如果将同一个操作定义为一个web服务,两个服务如何匹配逻辑。 最佳答案 在Java中,模运算的结果与被除数的符号相同。在Ruby中,它与除数的符号相同。remainder()在Ruby中与被除数的符号相同。您可能还想引用modulooperation.