首页编程java编程java浮动是什么意思 如何在java中表达一个数在正负百分之二十间浮动

java浮动是什么意思 如何在java中表达一个数在正负百分之二十间浮动

编程之家2023-10-12130次浏览

大家好,今天给各位分享java浮动是什么意思的一些知识,其中也会对如何在java中表达一个数在正负百分之二十间浮动进行解释,文章篇幅可能偏长,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在就马上开始吧!

java浮动是什么意思 如何在java中表达一个数在正负百分之二十间浮动

c语言里面的float是什么意思

C语言中float浮点型数据类型,FLOAT数据类型用于存储单精度浮点数或双精度浮点数。

浮点数使用 IEEE(电气和电子工程师协会)格式。浮点类型的单精度值具有 4个字节,包括一个符号位、一个

8位 excess-127二进制指数和一个 23位尾数。

java浮动是什么意思 如何在java中表达一个数在正负百分之二十间浮动

尾数表示一个介于 1.0和 2.0之间的数。由于尾数的高顺序位始终为 1,因此它不是以数字形式存储的。此表示形式为 float类型提供了一个大约在-3.4E+38和 3.4E+38之间的范围。

扩展资料

float造成的影响:

java浮动是什么意思 如何在java中表达一个数在正负百分之二十间浮动

1、对其兄弟元素(浮动)的影响

当一个浮动元素在浮动过程中碰到同一个方向的浮动元素时,它会紧跟在它们后面,可以用这样一个形象的比喻来在一个购票中心里,某人从一条购票队列跑到旁边的一条购票队列中排队,那自然先跑过去的会先占据前面的位置。

2、float对自身元素的影响

float对象将被视作块对象(block-level),即display属性等于block。

3、float对子元素的影响

我们知道当一个元素浮动时,在没有清楚浮动的情况下,它无法撑开其父元素,但它可以让自己的浮动子元素撑开它自身,并且在没有定义具体宽度情况下,使自身的宽度从100%变为自适应(浮动元素display:block)。其高度和宽度均为浮动元素高度和非浮动元素高度之间的最大值。

参考资料来源:百度百科-FLOAT

这段JAVA代码什么意思

javax.crypto.Cipher类提供加密和解密功能,该类是JCE框架的核心。

一,与所有的引擎类一样,可以通过调用Cipher类中的getInstance静态工厂方法得到Cipher对象。

public static Cipher getInstance(String transformation);

public static Cipher getInstance(String transformation,String provider);

参数transformation是一个字符串,它描述了由指定输入产生输出所进行的操作或操作集合。

参数transformation总是包含密码学算法名称,比如DES,也可以在后面包含模式和填充方式。

参数transformation可以是下列两种形式之一:

“algorithm/mode/padding”

“algorithm”

例如下面的例子就是有效的transformation形式:

"DES/CBC/PKCS5Padding"

"DES"

如果没有指定模式或填充方式,就使用特定提供者指定的默认模式或默认填充方式。例如,SunJCE提供者使用ECB作为DES、DES-EDE和 Blowfish等Cipher的默认模式,并使用PKCS5Padding作为它们默认的填充方案。这意味着在SunJCE提供者中,下列形式的声明是等价的:Cipher c1=Cipher.getInstance("DES/ECB/PKCS5Padding");

Cipher c1=Cipher.getInstance("DES");

当以流加密方式请求以块划分的cipher时,可以在模式名后面跟上一次运算需要操作的bit数目,例如采用"DES/CFB8/NoPadding"和"DES/OFB32/PKCS5Padding"形式的transformation参数。如果没有指定数目,则使用提供者指定的默认值(例如 SunJCE提供者使用的默认值是64bit)。

getInstance工厂方法返回的对象没有进行初始化,因此在使用前必须进行初始化。

通过getInstance得到的Cipher对象必须使用下列四个模式之一进行初始化,这四个模式在Cipher类中被定义为final integer常数,我们可以使用符号名来引用这些模式:

ENCRYPT_MODE,加密数据

DECRYPT_MODE,解密数据

WRAP_MODE,将一个Key封装成字节,可以用来进行安全传输

UNWRAP_MODE,将前述已封装的密钥解开成java.security.Key对象

每个Cipher初始化方法使用一个模式参数opmod,并用此模式初始化Cipher对象。此外还有其他参数,包括密钥key、包含密钥的证书certificate、算法参数params和随机源random。

我们可以调用以下的init方法之一来初始化Cipher对象:

public void init(int opmod,Key key);

public void init(int opmod,Certificate certificate);

public void init(int opmod,Key key,SecureRandom random);

public void init(int opmod,Certificate certificate,SecureRandom random);

public void init(int opmod,Key key,AlgorithmParameterSpec params);

public void init(int opmod,Key key,AlgorithmParameterSpec params,SecureRandom random);

public void init(int opmod,Key key,AlgorithmParameters params);

public void init(int opmod,Key key,AlgorithmParameters params,SecureRandom random);

必须指出的是,加密和解密必须使用相同的参数。当Cipher对象被初始化时,它将失去以前得到的所有状态。即,初始化Cipher对象与新建一个Cipher实例然后将它初始化是等价的。

二,可以调用以下的doFinal()方法之一完成单步的加密或解密数据:

public byte[] doFinal(byte[] input);

public byte[] doFinal(byte[] input,int inputOffset,int inputLen);

public int doFinal(byte[] input,int inputOffset,int inputLen,byte[] output);

public int doFinal(byte[] input,int inputOffset,int inputLen,byte[] output,int outputOffset);

在多步加密或解密数据时,首先需要一次或多次调用update方法,用以提供加密或解密的所有数据:

public byte[] update(byte[] input);

public byte[] update(byte[] input,int inputOffset,int inputLen);

public int update(byte[] input,int inputOffset,int inputLen,byte[] output);

public int update(byte[] input,int inputOffset,int inputLen,byte[] output,int outputOffset);

如果还有输入数据,多步操作可以使用前面提到的doFinal方法之一结束。如果没有数据,多步操作可以使用下面的doFinal方法之一结束:

public byte[] doFinal();

public int doFinal(byte[] output,int outputOffset);

如果在transformation参数部分指定了padding或unpadding方式,则所有的doFinal方法都要注意所用的padding或unpadding方式。

调用doFinal方法将会重置Cipher对象到使用init进行初始化时的状态,就是说,Cipher对象被重置,使得可以进行更多数据的加密或解密,至于这两种模式,可以在调用init时进行指定。

三,包裹wrap密钥必须先使用WRAP_MODE初始化Cipher对象,然后调用以下方法:

public final byte[] wrap(Key key);

如果将调用wrap方法的结果(wrap后的密钥字节)提供给解包裹unwrap的人使用,必须给接收者发送以下额外信息:

(1)密钥算法名称:

密钥算法名称可以调用Key接口提供的getAlgorithm方法得到:

public String getAlgorithm();

(2)被包裹密钥的类型(Cipher.SECRET_KEY,Cipher.PRIVATE_KEY,Cipher.PUBLIC_KEY)

sourcelink: http://bbs.sdu.edu.cn/pc/pccon.php?id=1292&nid=41716&order=&tid=

为了对调用wrap方法返回的字节进行解包,必须先使用UNWRAP_MODE模式初始化Cipher对象,然后调用以下方法:

public final Key unwrap(byte[] wrappedKey,String wrappedKeyAlgorithm,int wrappedKeyType));

其中,参数wrappedKey是调用wrap方法返回的字节,参数wrappedKeyAlgorithm是用来包裹密钥的算法,参数 wrappedKeyType是被包裹密钥的类型,该类型必须是Cipher.SECRET_KEY,Cipher.PRIVATE_KEY, Cipher.PUBLIC_KEY三者之一。

四,SunJCE提供者实现的cipher算法使用如下参数:

(1)采用CBC、CFB、OFB、PCBC模式的DES、DES-EDE和Blowfish算法。,它们使用初始化向量IV作为参数。可以使用javax.crypto.spec.IvParameterSpec类并使用给定的IV参数来初始化Cipher对象。

(2)PBEWithMD5AndDES使用的参数是一个由盐值和迭代次数组成的参数集合。可以使用javax.crypto.spec.PBEParameterSpec类并利用给定盐值和迭代次数来初始化Cipher对象。

注意:如果使用SealedObject类,就不必为解密运算参数的传递和保存担心。这个类在加密对象内容中附带了密封和加密的参数,可以使用相同的参数对其进行解封和解密。

Cipher中的某些update和doFinal方法允许调用者指定加密或解密数据的输出缓存。此时,保证指定的缓存足够大以容纳加密或解密运算的结果是非常重要的

如何在java中表达一个数在正负百分之二十间浮动

以int类型为例。10的浮动范围+-20%,那么就是8~12

-10的浮动范围+-20%,那么就是-12~-8

参考核心代码

publicstaticintfun1(intx,doublefd){

inty=(int)(Math.random()*(x+(x>=0?1:-1))*fd)*(Math.random()>0.5?1:-1);

returnx+y;

}

完整的代码

publicclassDemo{

publicstaticvoidmain(String[]args){

doublefd=0.2;//浮动的范围

intx=10;//需要浮动的数字

//intx=-10;

for(inti=0;i<50;i++){//循环50次,方便查看浮动的结果

System.out.println(fun1(x,fd));//调用方法一

//System.out.println(fun2(x,fd));//调用方法二

}

}

//方法一:写法比较简洁,不太好理解

publicstaticintfun1(intx,doublefd){

inty=(int)(Math.random()*(x+(x>=0?1:-1))*fd)*(Math.random()>0.5?1:-1);

returnx+y;

}

//方法二:写法比较啰嗦,但是好理解

publicstaticintfun2(intx,doublefd){

inty;

intnum;

if(x>=0){

y=(int)(Math.random()*(x+1)*fd);

}else{

y=(int)(Math.random()*(x-1)*fd);

}

doublez=Math.random();

if(z>0.5){

num=x+y;

}else{

num=x-y;

}

returnnum;

}

}

运行输出

浮动后的值是:11

浮动后的值是:10

浮动后的值是:12

浮动后的值是:10

浮动后的值是:10

浮动后的值是:8

....

关于java浮动是什么意思到此分享完毕,希望能帮助到您。

坐井观天是什么生肖(十二生肖坐井观天是什么生肖)什么是java内存?java heap space是什么意思