A. java中BigDecimal 的加減乘除和「+」「-」「*」「/」有什麼區別
BigDecimal用作商業計算的。
BigDecimal aDouble =new BigDecimal(1.22); 輸出:1.
BigDecimal aString = new BigDecimal("1.22"); 輸出:1.22
以上兩者輸出結果是不一樣的。
原因:
double的構造方法有不可預知性。
String的構造方法是固定的值。
所以如果類型是Double的話,而且需要精確計算,就用下面方法:
Double.toString(double)方法,可以先轉為String,然後再用new BigDecimal("")構造方法。
注意:BigDecimal都是不可變的(immutable)的,在進行每一步運算時,都會產生一個新的對象,所以在做加減乘除運算時千萬要保存操作後的值
Demo測試
publicstaticfinalvoidmain(String[]args){
BigDecimalaBigDecimal=newBigDecimal("1.1");
BigDecimalbBigDecimal=newBigDecimal("2.0");
BigDecimalsubtract=bBigDecimal.subtract(aBigDecimal);
System.out.println("使用BigDecimal進行相減計算:"+subtract.doubleValue());
System.out.println("直接相減:"+(2.0-1.1));
結果:
使用BigDecimal進行相減計算:0.9
直接相減:0.8999999999999999
B. java中有類似支持C語言的MIRACL大數運算庫嗎,可以實現模冪運算的,大數加減乘除之類的
參考jdk中的BigInteger和BigDecinal類,它們定義了你所需要的大數運算
C. java計算器的源代碼
import java.awt.*;
import java.awt.event.*;
import java.lang.*;
import javax.swing.*;
public class Counter extends Frame
{
//聲明三個面板的布局
GridLayout gl1,gl2,gl3;
Panel p0,p1,p2,p3;
JTextField tf1;
TextField tf2;
Button b0,b1,b2,b3,b4,b5,b6,b7,b8,b9,b10,b11,b12,b13,b14,b15,b16,b17,b18,b19,b20,b21,b22,b23,b24,b25,b26;
StringBuffer str;//顯示屏所顯示的字元串
double x,y;//x和y都是運算數
int z;//Z表示單擊了那一個運算符.0表示"+",1表示"-",2表示"*",3表示"/"
static double m;//記憶的數字
public Counter()
{
gl1=new GridLayout(1,4,10,0);//實例化三個面板的布局
gl2=new GridLayout(4,1,0,15);
gl3=new GridLayout(4,5,10,15);
tf1=new JTextField(27);//顯示屏
tf1.setHorizontalAlignment(JTextField.RIGHT);
tf1.setEnabled(false);
tf1.setText("0");
tf2=new TextField(10);//顯示記憶的索引值
tf2.setEditable(false);
//實例化所有按鈕、設置其前景色並注冊監聽器
b0=new Button("Backspace");
b0.setForeground(Color.red);
b0.addActionListener(new Bt());
b1=new Button("CE");
b1.setForeground(Color.red);
b1.addActionListener(new Bt());
b2=new Button("C");
b2.setForeground(Color.red);
b2.addActionListener(new Bt());
b3=new Button("MC");
b3.setForeground(Color.red);
b3.addActionListener(new Bt());
b4=new Button("MR");
b4.setForeground(Color.red);
b4.addActionListener(new Bt());
b5=new Button("MS");
b5.setForeground(Color.red);
b5.addActionListener(new Bt());
b6=new Button("M+");
b6.setForeground(Color.red);
b6.addActionListener(new Bt());
b7=new Button("7");
b7.setForeground(Color.blue);
b7.addActionListener(new Bt());
b8=new Button("8");
b8.setForeground(Color.blue);
b8.addActionListener(new Bt());
b9=new Button("9");
b9.setForeground(Color.blue);
b9.addActionListener(new Bt());
b10=new Button("/");
b10.setForeground(Color.red);
b10.addActionListener(new Bt());
b11=new Button("sqrt");
b11.setForeground(Color.blue);
b11.addActionListener(new Bt());
b12=new Button("4");
b12.setForeground(Color.blue);
b12.addActionListener(new Bt());
b13=new Button("5");
b13.setForeground(Color.blue);
b13.addActionListener(new Bt());
b14=new Button("6");
b14.setForeground(Color.blue);
b14.addActionListener(new Bt());
b15=new Button("*");
b15.setForeground(Color.red);
b15.addActionListener(new Bt());
b16=new Button("%");
b16.setForeground(Color.blue);
b16.addActionListener(new Bt());
b17=new Button("1");
b17.setForeground(Color.blue);
b17.addActionListener(new Bt());
b18=new Button("2");
b18.setForeground(Color.blue);
b18.addActionListener(new Bt());
b19=new Button("3");
b19.setForeground(Color.blue);
b19.addActionListener(new Bt());
b20=new Button("-");
b20.setForeground(Color.red);
b20.addActionListener(new Bt());
b21=new Button("1/X");
b21.setForeground(Color.blue);
b21.addActionListener(new Bt());
b22=new Button("0");
b22.setForeground(Color.blue);
b22.addActionListener(new Bt());
b23=new Button("+/-");
b23.setForeground(Color.blue);
b23.addActionListener(new Bt());
b24=new Button(".");
b24.setForeground(Color.blue);
b24.addActionListener(new Bt());
b25=new Button("+");
b25.setForeground(Color.red);
b25.addActionListener(new Bt());
b26=new Button("=");
b26.setForeground(Color.red);
b26.addActionListener(new Bt());
//實例化四個面板
p0=new Panel();
p1=new Panel();
p2=new Panel();
p3=new Panel();
//創建一個空字元串緩沖區
str=new StringBuffer();
//添加面板p0中的組件和設置其在框架中的位置和大小
p0.add(tf1);
p0.setBounds(10,25,300,40);
//添加面板p1中的組件和設置其在框架中的位置和大小
p1.setLayout(gl1);
p1.add(tf2);
p1.add(b0);
p1.add(b1);
p1.add(b2);
p1.setBounds(10,65,300,25);
//添加面板p2中的組件並設置其的框架中的位置和大小
p2.setLayout(gl2);
p2.add(b3);
p2.add(b4);
p2.add(b5);
p2.add(b6);
p2.setBounds(10,110,40,150);
//添加面板p3中的組件並設置其在框架中的位置和大小
p3.setLayout(gl3);//設置p3的布局
p3.add(b7);
p3.add(b8);
p3.add(b9);
p3.add(b10);
p3.add(b11);
p3.add(b12);
p3.add(b13);
p3.add(b14);
p3.add(b15);
p3.add(b16);
p3.add(b17);
p3.add(b18);
p3.add(b19);
p3.add(b20);
p3.add(b21);
p3.add(b22);
p3.add(b23);
p3.add(b24);
p3.add(b25);
p3.add(b26);
p3.setBounds(60,110,250,150);
//設置框架中的布局為空布局並添加4個面板
setLayout(null);
add(p0);
add(p1);
add(p2);
add(p3);
setResizable(false);//禁止調整框架的大小
//匿名類關閉窗口
addWindowListener(new WindowAdapter(){
public void windowClosing(WindowEvent e1)
{
System.exit(0);
}
});
setBackground(Color.lightGray);
setBounds(100,100,320,280);
setVisible(true);
}
//構造監聽器
class Bt implements ActionListener
{
public void actionPerformed(ActionEvent e2)
{
try{
if(e2.getSource()==b1)//選擇"CE"清零
{
tf1.setText("0");//把顯示屏清零
str.setLength(0);//清空字元串緩沖區以准備接收新的輸入運算數
}
else if(e2.getSource()==b2)//選擇"C"清零
{
tf1.setText("0");//把顯示屏清零
str.setLength(0);
}
else if(e2.getSource()==b23)//單擊"+/-"選擇輸入的運算數是正數還是負數
{
x=Double.parseDouble(tf1.getText().trim());
tf1.setText(""+(-x));
}
else if(e2.getSource()==b25)//單擊加號按鈕獲得x的值和z的值並清空y的值
{
x=Double.parseDouble(tf1.getText().trim());
str.setLength(0);//清空緩沖區以便接收新的另一個運算數
y=0d;
z=0;
}
else if(e2.getSource()==b20)//單擊減號按鈕獲得x的值和z的值並清空y的值
{
x=Double.parseDouble(tf1.getText().trim());
str.setLength(0);
y=0d;
z=1;
}
else if(e2.getSource()==b15)//單擊乘號按鈕獲得x的值和z的值並清空y的值
{
x=Double.parseDouble(tf1.getText().trim());
str.setLength(0);
y=0d;
z=2;
}
else if(e2.getSource()==b10)//單擊除號按鈕獲得x的值和z的值並空y的值
{
x=Double.parseDouble(tf1.getText().trim());
str.setLength(0);
y=0d;
z=3;
}
else if(e2.getSource()==b26)//單擊等號按鈕輸出計算結果
{
str.setLength(0);
switch(z)
{
case 0 : tf1.setText(""+(x+y));break;
case 1 : tf1.setText(""+(x-y));break;
case 2 : tf1.setText(""+(x*y));break;
case 3 : tf1.setText(""+(x/y));break;
}
}
else if(e2.getSource()==b24)//單擊"."按鈕輸入小數
{
if(tf1.getText().trim().indexOf(′.′)!=-1)//判斷字元串中是否已經包含了小數點
{
}
else//如果沒數點有小
{
if(tf1.getText().trim().equals("0"))//如果初時顯示為0
{
str.setLength(0);
tf1.setText((str.append("0"+e2.getActionCommand())).toString());
}
else if(tf1.getText().trim().equals(""))//如果初時顯示為空則不做任何操作
{
}
else
{
tf1.setText(str.append(e2.getActionCommand()).toString());
}
}
y=0d;
}
else if(e2.getSource()==b11)//求平方根
{
x=Double.parseDouble(tf1.getText().trim());
tf1.setText("數字格式異常");
if(x<0)
tf1.setText("負數沒有平方根");
else
tf1.setText(""+Math.sqrt(x));
str.setLength(0);
y=0d;
}
else if(e2.getSource()==b16)//單擊了"%"按鈕
{
x=Double.parseDouble(tf1.getText().trim());
tf1.setText(""+(0.01*x));
str.setLength(0);
y=0d;
}
else if(e2.getSource()==b21)//單擊了"1/X"按鈕
{
x=Double.parseDouble(tf1.getText().trim());
if(x==0)
{
tf1.setText("除數不能為零");
}
else
{
tf1.setText(""+(1/x));
}
str.setLength(0);
y=0d;
}
else if(e2.getSource()==b3)//MC為清除內存
{
m=0d;
tf2.setText("");
str.setLength(0);
}
else if(e2.getSource()==b4)//MR為重新調用存儲的數據
{
if(tf2.getText().trim()!="")//有記憶數字
{
tf1.setText(""+m);
}
}
else if(e2.getSource()==b5)//MS為存儲顯示的數據
{
m=Double.parseDouble(tf1.getText().trim());
tf2.setText("M");
tf1.setText("0");
str.setLength(0);
}
else if(e2.getSource()==b6)//M+為將顯示的數字與已經存儲的數據相加要查看新的數字單擊MR
{
m=m+Double.parseDouble(tf1.getText().trim());
}
else//選擇的是其他的按鈕
{
if(e2.getSource()==b22)//如果選擇的是"0"這個數字鍵
{
if(tf1.getText().trim().equals("0"))//如果顯示屏顯示的為零不做操作
{
}
else
{
tf1.setText(str.append(e2.getActionCommand()).toString());
y=Double.parseDouble(tf1.getText().trim());
}
}
else if(e2.getSource()==b0)//選擇的是「BackSpace」按鈕
{
if(!tf1.getText().trim().equals("0"))//如果顯示屏顯示的不是零
{
if(str.length()!=1)
{
tf1.setText(str.delete(str.length()-1,str.length()).toString());//可能拋出字元串越界異常
}
else
{
tf1.setText("0");
str.setLength(0);
}
}
y=Double.parseDouble(tf1.getText().trim());
}
else//其他的數字鍵
{
tf1.setText(str.append(e2.getActionCommand()).toString());
y=Double.parseDouble(tf1.getText().trim());
}
}
}
catch(NumberFormatException e){
tf1.setText("數字格式異常");
}
catch( e){
tf1.setText("字元串索引越界");
}
}
}
public static void main(String args[])
{
new Counter();
}
}
你在JAVA的環境中運行一下。
這題目也是我的作業,我運行的了。
D. 編寫程序來執行兩個數字12和5的算術加法,乘法和除法(java程序)求源代碼
樓上的除法運算出錯,a
/
b取商,a%b取余,同數學運算是有差異的。還有就是雙精度浮點數的加減乘除會損失精度。建議用BigDecimal提供的方法來運算。
如:
BigDecimal
a
=
new
BigDecimal(12);
BigDecimal
b
=
new
BigDecimal(5);
加法運算:a=a.add(b);
減法運算:a=a.subtract(b);
乘法運算:a=a.multiply(b);
除法運算:a=a.divide(b);
獲取運算結果:a.toString()
,
a.longValue()
,
a.intValue()
.....等等
保留兩位小數,四捨五入:a=a.divide(b).setScale(2,
BigDecimal.ROUND_HALF_UP);
大量方法建議自查api文檔。
E. eclipse關於次冪的運算問題,來大佬~
看Math.pow的源代碼發現其調用的是 StrictMath下的
public static native double pow(double a, double b);
方法。
這個方法是native的實現是在jvm源碼中的,可能是由c or cpp 寫的,我們就不去糾結了。
這個方法上面有很詳細的comment,你可以看看這個結果為什麼是infinity,它有多個case 都可以導致結果為infinity。
籠統來講就是超界了,至於為啥是字元串的結果,那麼源碼的注釋中寫了,就是這么規定的。
F. java new BigDecimal("2321") 源代碼是怎樣處理的
自己看jdk目錄下src.zip里的代碼
G. 如何獲取BigDecimal的負數
簡單數值類型才支持+-*/
BigDecimal是對象類型,要通過相應的方法來計算
for example
Java code
BigDecimal decimal = new BigDecimal(123);
decimal = decimal.multiply(new BigDecimal(-1));
System.out.println(decimal)。
(7)bigdecimal源碼擴展閱讀:
BigDecimail 轉負數negate()
new BigDecimail().negate() 返回負數
源碼:
/** * Returns a {@code BigDecimal} whose value is {@code (-this)},* and whose scale is {@code this.scale()}.
*
* @return {@code -this}.
*/
if (intCompact == INFLATED) {
return new BigDecimal(intVal.negate(), INFLATED, scale, precision);
} else { return valueOf(-intCompact, scale, precision); } }
H. java中的new BigDecimal(0)是什麼意思
new BigDecimal(0)有可能得到的是0.000000000000001之類的值,這是Java的bug。初始化0或者其他基礎類型數字轉換為BigDecimal最好用字元串。
比如初始化為0,用new BigDecimal("0")
I. 用java編寫計算器,類,方法,屬性的說明
簡易的計算器
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.math.BigDecimal;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JTextField;
public class Calcular implements ActionListener {
JTextField jtf = new JTextField(10);
boolean flag = false;
boolean emblem = false;
@SuppressWarnings("static-access")
public Calcular() {
JFrame jf = new JFrame("testcalcular");
jf.setLayout(new BorderLayout());
jtf.setEditable(false);
jtf.setHorizontalAlignment(JTextField.RIGHT);
jtf.setText("0");
JPanel jp = new JPanel();
jp.setLayout(new GridLayout(5, 4));
String[] lab = { "BACK", "CE", "C", "+", "7", "8", "9", "-", "4", "5",
"6", "*", "3", "2", "1", "/", "0", "+/-", ".", "=" };
JButton[] jb = new JButton[lab.length];
for (int i = 0; i < jb.length; i++) {
jb[i] = new JButton(lab[i]);
if (lab[i].matches("^\\d$")) {
jb[i].setBackground(Color.PINK);
} else if (lab[i].matches("^[a-zA-Z]+$")) {
jb[i].setBackground(Color.GREEN);
} else {
jb[i].setBackground(Color.LIGHT_GRAY);
}
jb[i].addActionListener(this);
jp.add(jb[i]);
}
jf.add(jtf, BorderLayout.NORTH);
jf.add(jp);
jf.setSize(300, 200);
jf.setLocation(300, 200);
jf.setResizable(false);
jf.setVisible(true);
jf.setDefaultCloseOperation(jf.EXIT_ON_CLOSE);
}
public static void main(String[] args) {
new Calcular();
}
public void actionPerformed(ActionEvent e) {
String comm = e.getActionCommand();
if ("CE".equals(comm)) {
jtf.setText("0");
flag = false;
emblem = false;
} else if ("C".equals(comm)) {
jtf.setText("0");
flag = false;
emblem = false;
} else if ("BACK".equals(comm)) {
String com = jtf.getText() + comm;
com = com.substring(0, com.length() - 5);
if (com.length() == 0) {
jtf.setText("0");
flag = false;
} else {
jtf.setText(com);
}
} else if ("+-*/".contains(comm)) {
if (emblem) {
String num = number(jtf.getText());
jtf.setText(num + comm);
emblem = false;
} else {
String number = jtf.getText() + comm;
jtf.setText(number);
emblem = true;
}
} else if ("=".equals(comm)) {
emblem = false;
jtf.setText(number(jtf.getText()));
} else if ("+/-".equals(comm)) {
String com = jtf.getText();
com = com.substring(0, 1);
if ("-".equals(com)) {
com = jtf.getText();
com = com.substring(1, com.length());
jtf.setText(com);
} else {
com = "-" + jtf.getText();
jtf.setText(com);
}
} else {
if (flag) {
String com = jtf.getText() + comm;
jtf.setText(com);
} else {
jtf.setText(comm);
if ("0".equals(comm)) {
flag = false;
} else {
flag = true;
}
}
}
}
public String number(String s) {
BigDecimal a = null;
String ss = "^[-]{1}\\d+[\\+\\-\\*\\/]{1}\\d+$";
String sss = "^\\d+[\\+\\-\\*\\/]{1}\\d+$";
if (s.matches(sss)) {
if (s.contains("*")) {
String[] str = s.split("\\*");
BigDecimal b1 = new BigDecimal(str[0]);
BigDecimal b2 = new BigDecimal(str[1]);
a = b1.multiply(b2);
}
if (s.contains("/")) {
String[] str = s.split("\\/");
BigDecimal b1 = new BigDecimal(str[0]);
BigDecimal b2 = new BigDecimal(str[1]);
a = b1.divide(b2, 10, BigDecimal.ROUND_HALF_UP);
}
if (s.contains("+")) {
String[] str = s.split("\\+");
BigDecimal b1 = new BigDecimal(str[0]);
BigDecimal b2 = new BigDecimal(str[1]);
a = b1.add(b2);
}
if (s.contains("-")) {
String[] str = s.split("\\-");
BigDecimal b1 = new BigDecimal(str[0]);
BigDecimal b2 = new BigDecimal(str[1]);
a = b1.subtract(b2);
}
} else if (s.matches(ss)) {
s = s.substring(1);
if (s.contains("*")) {
String[] str = s.split("\\*");
BigDecimal b1 = new BigDecimal("-" + str[0]);
BigDecimal b2 = new BigDecimal(str[1]);
a = b1.multiply(b2);
}
if (s.contains("/")) {
String[] str = s.split("\\/");
BigDecimal b1 = new BigDecimal("-" + str[0]);
BigDecimal b2 = new BigDecimal(str[1]);
a = b1.divide(b2, 10, BigDecimal.ROUND_HALF_UP);
}
if (s.contains("+")) {
String[] str = s.split("\\+");
BigDecimal b1 = new BigDecimal("-" + str[0]);
BigDecimal b2 = new BigDecimal(str[1]);
a = b1.add(b2);
}
if (s.contains("-")) {
String[] str = s.split("\\-");
BigDecimal b1 = new BigDecimal("-" + str[0]);
BigDecimal b2 = new BigDecimal(str[1]);
a = b1.subtract(b2);
}
} else {
return "ERROR";
}
return a.toString();
}
}