用Java实现在【520,1314】之间生成随机整数的故事

做一个积极的人编码、改bug、提升自己我有一个乐园,面向编程,春暖花开!在未来城市工作的的程序员小木,做了一个梦,梦到自己在塔鲁姆的街道上看到一个姑娘,这个姑娘从远处走向他,脸上带着微笑。让小木很是着迷,小木呆呆的望着姑娘从他身边走过,当他回过神来,发现姑娘已经走远,小木赶忙去追这位姑娘,突然天空中飘下一张字条,上面写着:我一眼就看出你是Java程序员了,当你能用代码实现 520~1…

大家好,又见面了,我是全栈君。

做一个积极的人

编码、改bug、提升自己

我有一个乐园,面向编程,春暖花开!

=================================================

对人工智能感兴趣的伙伴,分享一个我朋友的人工智能教程。零基础!通俗易懂!风趣幽默!大家可以看看是否对自己有帮助,点击这里查看教程

=================================================

在未来城市工作的的程序员小木,做了一个梦,梦到自己在塔鲁姆的街道上看到一个姑娘,这个姑娘从远处走向他,脸上带着微笑。让小木很是着迷,小木呆呆的望着姑娘从他身边走过,当他回过神来,发现姑娘已经走远,小木赶忙去追这位姑娘,突然天空中飘下一张字条,上面写着:

我一眼就看出你是Java程序员了,当你能用代码实现 520~1314 之间的随机整数,那么我会主动来找你的!

小木还很纳闷,为什么这个姑娘知道自己是一个程序员,姑娘难道是上天专门派来的吗 ?

小木同学,见下图:

用Java实现在【520,1314】之间生成随机整数的故事

小木很兴奋啊,终于我学的Java编程有用武之处了,这个比写CRUD和看项目留下的烂代码好很多啊,我写好了,姑娘就来找我了。小木大脑开始快速运转,脑神经之间相互发送消息,收集储存起来的数据。

用Java实现在【520,1314】之间生成随机整数的故事

几秒之后,小木想到了一个方法,在刚开始学习Java的时候学过一个 Math 类,它里面有一个生成随机数的方法random()。但是通过Math.random() 获取的随机数是[0,1)之间的double值。注:包含0,但1不包含!

那要获取整数,则需要将上面的结果转行成int类型即可。获取[0, 1)之间的int整数。方法如下:

double d = Math.random();
// [0, 1)
int love = (int) (d);
// randNumber 将被赋值为一个 MIN 和 MAX 范围内的随机数
int randNumber = rand.nextInt(MAX - MIN + 1) + MIN;

简单思考:要让值落在520~1314,那么

MAX : 1314

MIN: 520

因为 Math.random() 获取[0, 1),换算公式: (Math.random() * (MAX – MIN)) + MIN

根据公式照葫芦画瓢,小木很快就实现随机 520~1314 的代码了!

 double d = Math.random();
// [520, 1314)
int love = (int) (d * (1314-520)) + 520;

写完上面的代码后,小木想还是要检查检查,不能马虎大意,毕竟这关乎姑娘会不会来找自己。代码运行N多遍之后,520是包含了,但是1314 怎么也出现不了!小木很快意识到这问题很严重。没有1314 姑娘找他这件事肯定就泡汤了。重新看上面的换算公式, 小木发现公式有点问题,少了个 1 啊!

正确的公式是 : (Math.random() * (MAX – MIN + 1)) + MIN

 double d = Math.random();
// [520, 1315)
int love = (int) (d * (1314 - 520 + 1) + 520;

这样就完美一点了,随机数就可以包含1314,这样就可以[520,1314]了。

注: 为了方便阅读,括号内就没有直接写出运算后的值。

大脑还处在高速运转的小木,实现了上面的功能后,心想这么容易就能约到姑娘了,这是不是有点太简单了。于是又想还有没有其他办法还能实现此功能呢?又想到了有Math.random()。不是还有一个Random类嘛,和Random类一起的还有一个ThreadLocalRandom类。不管咋,我在用一种方法实现以下,好好表现一下自己也好!

使用Random获取[520, 1314]之间的int整数,Random 对象的nextInt(int) 方法,将生成 [0, int)之间随机取值的整数。根据上面的思路,实现代码如下:

Random random = new Random();
// [520,1315) == [520,1314]
int love = (random.nextInt(1314 - 520 + 1) + 520);

小木在上面代码下面备注了如下内容:

1、Random类采用AtomicLong实现,保证多线程的线程安全性,但是多线程并发获取随机数时性能较差。

2、ThreadLocalRandom就实现了,ThreadLocalRandom继承了Random。多线程环境中可以使用ThreadLocalRandom作为随机数生成器,ThreadLocalRandom采用了线程局部变量来改善性能。

最后当小木写完代码后,听到早晨的闹钟响了,美梦就这样被闹钟无情的敲碎了,醒来后,小木久久不能忘记梦中的姑娘,想着什么时候能够再次偶遇!

用Java实现在【520,1314】之间生成随机整数的故事

你期待小木和梦中姑娘的的再次相遇嘛,我真的还期待,说不定一段美妙的爱情火花就会擦出。


最后帮欢哥打波广告: 阿里口碑,杭州,Java工程师,感兴趣的伙伴可以私聊!



谢谢你的阅读,如果您觉得这篇博文对你有帮助,请点赞或者喜欢,让更多的人看到!祝你每天开心愉快!


不管做什么,只要坚持下去就会看到不一样!在路上,不卑不亢!

博客首页 : https://aflyun.blog.csdn.net/

愿你我在人生的路上能都变成最好的自己,能够成为一个独挡一面的人
用Java实现在【520,1314】之间生成随机整数的故事

© 每天都在变得更好的阿飞云

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/121015.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • cs模型介绍_cs武器介绍

    cs模型介绍_cs武器介绍1、C/S模型(Client/Server—客户端/服务端)—需要下载app2、B/S模型(Browser/Server—浏览器/服务端)—网页浏览即可

    2022年9月17日
    0
  • JavaScript实现哈希表数据结构[通俗易懂]

    一、简单说明1、JavaScript是没有哈希表数据结构的,那么当我们需要用到类似哈希表这样的键值对数据结构时怎么办?答案就是自己实现一个,我们可以利用JavaScript的一些特性来实现自己的哈希表数据结构。2、首先,哈希表是一种键值对数据结构,键是唯一的,这个特征跟JavaScript的Object对象有点类似,Object对象的属性是唯一的,属性和值的映射就像是键值对一样,那么我们可以用一个…

    2022年4月9日
    60
  • 【数据结构】— kmp算法和strstr函数

    【数据结构】— kmp算法和strstr函数kmp算法和strstr函数注:现实生活中,字符串匹配在很多的应用场景里都有着极其重要的作用,包括生物信息学、信息检索、拼写检查、语言翻译、数据压缩、网络入侵检测等等,至此诞生了很多的算法,那么我们今天就来探索这两种经典的算法。一、概念分析首先我们需要了解到什么是kmp算法和strstr函数概念如下:KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R….

    2022年6月25日
    21
  • ▲ Android 自定义搜索附近的动画

    ▲ Android 自定义搜索附近的动画

    2021年3月12日
    153
  • 乐观锁和悲观锁实现(java乐观锁实现)

    推荐阅读:如何在技术领域持续成长后端程序员必备的Linux基础知识后端必备——数据通信知识(RPC、消息队列)一站式总结何谓悲观锁与乐观锁乐观锁对应于生活中乐观的人总是想着事情往好的方向发展,悲观锁对应于生活中悲观的人总是想着事情往坏的方向发展。这两种人各有优缺点,不能不以场景而定说一种人好于另外一种人。悲观锁总是假设最坏的情况,每次去拿数据的时候都认为…

    2022年4月18日
    46
  • Fuel 5.1安装openstack I版本号环境

    Fuel 5.1安装openstack I版本号环境

    2022年1月3日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号