本文整理汇总了Scala中java.util.concurrent.ThreadLocalRandom类的典型用法代码示例。如果您正苦于以下问题:Scala ThreadLocalRandom类的具体用法?Scala ThreadLocalRandom怎么用?Scala ThreadLocalRandom使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了ThreadLocalRandom类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Scala代码示例。
示例1: Main
//设置package包名称以及导入依赖的类
package lazyvar2
import java.util.concurrent.ThreadLocalRandom
object Main {
val txcount = 100000
def main(args : Array[String]) : Unit = {
val state = Array.ofDim[LazyVar[Int]](100)
for(i <- 0 until state.length)
state(i) = new LazyVar(0)
// note: lazy reads do not improve performance in this model, because they must be locked anyway, so they could be read immediately
// they do improve performance if they can actually be read lazily
while(true) {
val begin = System.nanoTime()
for(i <- (0 to txcount).par) {
val rnd = ThreadLocalRandom.current()
val tx = new Transaction()
for(i <- 1 to 10)
tx.update(state(rnd.nextInt(state.size)), (x : Int) => x + 1)
tx.commit
}
val end = System.nanoTime()
val time = (end - begin) / 1000000000.0
println(txcount / time)
}
}
}
示例2: Util
//设置package包名称以及导入依赖的类
package lazytx.benchmark.tpcc
import java.util.concurrent.ThreadLocalRandom
object Util {
val nameParts = Array("BAR", "OUGHT", "ABLE", "PRI", "PRES", "ESE", "ANTI", "CALLY", "ATION", "EING")
var names = Array.ofDim[String](1000)
for(i <- 0 to 999) {
names(i) = genname(i)
}
def c(a : Int) = rand(0, ThreadLocalRandom.current.nextInt(a))
def rand(a : Int, b : Int) : Int = ThreadLocalRandom.current().nextInt(b - a + 1) + a
def randa(length : Int) : String = {
var result = new StringBuilder(length)
val rnd = ThreadLocalRandom.current
for(i <- 1 to length) {
result.append(String.valueOf(('a' + rnd.nextInt(26)).toChar))
}
result.toString()
}
def randOriginal() : String = {
var r = randa(rand(26, 50))
if(rand(1, 10) == 1) {
r
} else {
val start = r.length() - 8
r.substring(0, start) + "ORIGINAL" + r.substring(start + 8, r.length)
}
}
def nurand(a : Int, x : Int, y : Int) = (((rand(0, a) | rand(x, y)) + c(a)) % (y - x + 1)) + x
def genname(n : Int) = nameParts(n / 100) + nameParts((n / 10) % 10) + nameParts(n % 10)
def name(n : Int) = names(n)
def permutation(count : Int) = {
var result = Array.ofDim[Int](count)
val rnd = ThreadLocalRandom.current
for(i <- 1 to count) {
result(i - 1) = i
}
for(i <- 0 to count - 1) {
val temp = result(i)
val s = i + (rnd.nextInt(count - i)).toInt
result(i) = result(s)
result(s) = temp
}
result
}
def new_order_key(w_id : Long, d_id : Long, o_id : Long) =
(w_id << 40) + (d_id << 32) + o_id
}
示例3: Base
//设置package包名称以及导入依赖的类
package com.spooky.inbound
import java.math.BigInteger
import java.util.concurrent.ThreadLocalRandom
import java.nio.charset.Charset
abstract class Base {
protected val DH_P = "FFFFFFFFFFFFFFFFC90FDAA22168C234C4C6628B80DC1CD129024E088A67CC74020BBEA63B139B22514A08798E3404DDEF9519B3CD3A431B302B0A6DF25F14374FE1356D6D51C245E485B576625E7EC6F44C42E9A63A36210000000000090563"
protected val DH_G = "02"
protected val DH_L = 160
protected val UTF8 = Charset.forName("UTF8");
protected val KEYA_IV = "keyA".getBytes(UTF8)
protected val KEYB_IV = "keyB".getBytes(UTF8)
protected val REQ1_IV = "req1".getBytes(UTF8)
protected val REQ2_IV = "req2".getBytes(UTF8)
protected val REQ3_IV = "req3".getBytes(UTF8)
protected val VC = Array[Byte](0, 0, 0, 0, 0, 0, 0, 0)
protected val RC4_STREAM_ALG = "RC4";
protected val DH_P_BI = new BigInteger(DH_P, 16)
protected val DH_G_BI = new BigInteger(DH_G, 16)
protected val DH_SIZE_BYTES = DH_P.length() / 2
protected val CRYPTO_PLAIN: Byte = Plain.id
protected val CRYPTO_RC4: Byte = RC4.id
protected val PADDING_MAX = 512
private def randomPaddingSize: Int = {
val random = ThreadLocalRandom.current
Math.abs(random.nextInt % PADDING_MAX)
}
protected def randomPadding(): Array[Byte] = {
val padding = Array.ofDim[Byte](randomPaddingSize)
val random = ThreadLocalRandom.current
random.nextBytes(padding)
padding
}
}
示例4: SessionUtil
//设置package包名称以及导入依赖的类
package com.softwaremill.session
import java.math.BigInteger
import java.util.concurrent.ThreadLocalRandom
import javax.xml.bind.DatatypeConverter
object SessionUtil {
def randomString(length: Int) = {
// http://stackoverflow.com/questions/41107/how-to-generate-a-random-alpha-numeric-string
val random = ThreadLocalRandom.current()
new BigInteger(length * 5, random).toString(32) // because 2^5 = 32
}
def randomServerSecret() = randomString(128)
// Do not change this unless you understand the security issues behind timing attacks.
// This method intentionally runs in constant time if the two strings have the same length.
// If it didn't, it would be vulnerable to a timing attack.
def constantTimeEquals(a: String, b: String) = {
if (a.length != b.length) {
false
}
else {
var equal = 0
for (i <- Array.range(0, a.length)) {
equal |= a(i) ^ b(i)
}
equal == 0
}
}
def toHexString(array: Array[Byte]): String = {
DatatypeConverter.printHexBinary(array)
}
def hexStringToByte(hexString: String): Array[Byte] = {
DatatypeConverter.parseHexBinary(hexString)
}
}
示例5: rnd
//设置package包名称以及导入依赖的类
package scaladays.akka.support
import java.util.concurrent.ThreadLocalRandom
import scala.util.Random
trait MakingUpData {
private def rnd = ThreadLocalRandom.current()
private def char = rnd.nextInt(65, 91).toChar
def shortNameId(): String = s"$char$char$char"
def shortName(): String = s"${char.toUpper}${char.toLower}${char.toLower}${char.toLower}${char.toLower}"
def lipsum(): String = Random.shuffle(lipsumWords).take(rnd.nextInt(5, 20)).mkString(" ") + "."
def int(): Int = rnd.nextInt(0, 101)
val lipsumWords = List(
"a", "ac", "accumsan", "ad", "adipiscing",
"aenean", "aliquam", "aliquet", "amet", "ante", "aptent", "arcu",
"at", "auctor", "augue", "bibendum", "blandit", "class", "commodo",
"condimentum", "congue", "consectetur", "consequat", "conubia",
"convallis", "cras", "cubilia", "cum", "curabitur", "curae",
"cursus", "dapibus", "diam", "dictum", "dictumst", "dignissim",
"dis", "dolor", "donec", "dui", "duis", "egestas", "eget",
"eleifend", "elementum", "elit", "enim", "erat", "eros", "est",
"et", "etiam", "eu", "euismod", "facilisi", "facilisis", "fames",
"faucibus", "felis", "fermentum", "feugiat", "fringilla", "fusce",
"gravida", "habitant", "habitasse", "hac", "hendrerit",
"himenaeos", "iaculis", "id", "imperdiet", "in", "inceptos",
"integer", "interdum", "ipsum", "justo", "lacinia", "lacus",
"laoreet", "lectus", "leo", "libero", "ligula", "litora",
"lobortis", "lorem", "luctus", "maecenas", "magna", "magnis",
"malesuada", "massa", "mattis", "mauris", "metus", "mi",
"molestie", "mollis", "montes", "morbi", "mus", "nam", "nascetur",
"natoque", "nec", "neque", "netus", "nibh", "nisi", "nisl", "non",
"nostra", "nulla", "nullam", "nunc", "odio", "orci", "ornare",
"parturient", "pellentesque", "penatibus", "per", "pharetra",
"phasellus", "placerat", "platea", "porta", "porttitor", "posuere",
"potenti", "praesent", "pretium", "primis", "proin", "pulvinar",
"purus", "quam", "quis", "quisque", "rhoncus", "ridiculus",
"risus", "rutrum", "sagittis", "sapien", "scelerisque", "sed",
"sem", "semper", "senectus", "sit", "sociis", "sociosqu",
"sodales", "sollicitudin", "suscipit", "suspendisse", "taciti",
"tellus", "tempor", "tempus", "tincidunt", "torquent", "tortor",
"tristique", "turpis", "ullamcorper", "ultrices", "ultricies",
"urna", "ut", "varius", "vehicula", "vel", "velit", "venenatis",
"vestibulum", "vitae", "vivamus", "viverra", "volutpat",
"vulputate"
)
}
示例6: BbcId
//设置package包名称以及导入依赖的类
package bbcid
import scala.concurrent.duration._
import io.gatling.core.Predef._
import io.gatling.http.Predef._
object BbcId {
import java.util.concurrent.ThreadLocalRandom
def register(pageToReturnTo: String = "/") = {
val encodedPageToReturnTo = java.net.URLEncoder.encode(pageToReturnTo, "UTF-8")
exec(_.set("email", s"[email protected]${ThreadLocalRandom.current.nextInt(Int.MaxValue)}.com"))
.exec(http("getBbcIdRegister")
.get("/id/register"))
.exec(http("postBbcIdRegister")
.post("/id/register?ptrt=" + encodedPageToReturnTo)
.formParam("email", "${email}")
.formParam("confirmpassword", "wwtest")
.formParam("confirmpassword_confirm", "wwtest")
.formParam("personalisedupdates", "0")
.formParam("personalisedupdates", "1")
.formParam("bbcid_submit_button", "Register")
.check(status is 200, css("#orb-modules h2") is "Your registration is complete"))
}
def signIn(pageToReturnTo: String = "/",
validation: String = "Welcome to the BBC") = {
val encodedPageToReturnTo = java.net.URLEncoder.encode(pageToReturnTo, "UTF-8")
val feeder = csv("bbcid/bbcid_emails.txt").circular
feed(feeder)
.exec(http("getBbcIdSignIn")
.get("/id/signin"))
.exec(http("postBbcIdSignIn")
.post("/id/signin?ptrt=" + encodedPageToReturnTo)
.formParam("unique", "${email}")
.formParam("password", "loadtest")
.formParam("rememberme", "1")
.check(status is 200, substring(validation)))
}
}
示例7: ComputerWorld
//设置package包名称以及导入依赖的类
package bbc.kraftwerk
import scala.concurrent.duration._
import io.gatling.core.Predef._
import io.gatling.http.Predef._
import java.util.concurrent.ThreadLocalRandom
class ComputerWorld extends Simulation {
val httpProtocol = http
.baseURL("http://computer-database.gatling.io")
.acceptHeader("""text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8""")
.acceptEncodingHeader("""gzip, deflate""")
.acceptLanguageHeader("""en-gb,en;q=0.5""")
.userAgentHeader("""Mozilla/5.0 (Macintosh; Intel Mac OS X 10.9; rv:31.0) Gecko/20100101 Firefox/31.0""")
val computerDbScn = scenario("Computer Scenario")
.exec(http("getComputers")
.get("/computers")
.check(
status is 200,
regex("""\d+ computers found"""),
css("#add", "href").saveAs("addComputer")))
.exec(http("addNewComputer")
.get("${addComputer}")
.check(substring("Add a computer")))
.exec(_.set("homeComputer", s"homeComputer_${ThreadLocalRandom.current.nextInt(Int.MaxValue)}"))
.exec(http("postComputers")
.post("/computers")
.formParam("name", "${homeComputer}")
.formParam("introduced", "2015-10-10")
.formParam("discontinued", "2017-10-10")
.formParam("company", "")
.check(substring("${homeComputer}")))
setUp(computerDbScn.inject(
constantUsersPerSec(2) during(10 minutes)
).protocols(httpProtocol))
}
示例8: random
//设置package包名称以及导入依赖的类
package com.github.jeroenr.tepkin.util
import java.util.concurrent.ThreadLocalRandom
trait Randomizer {
def random: ThreadLocalRandom = ThreadLocalRandom.current()
def randomString(alphabet: String)(n: Int): String = {
Stream.continually(random.nextInt(alphabet.size)).map(alphabet).take(n).mkString
}
def randomString(n: Int): String = {
randomString {
"""!"#$%&'()*+-./0123456789:;<=>[email protected][\]^_`abcdefghijklmnopqrstuvwxyz{|}~"""
}(n)
}
}
示例9: ComputerWorld
//设置package包名称以及导入依赖的类
package computerdatabase
import scala.concurrent.duration._
import java.util.concurrent.ThreadLocalRandom
import io.gatling.core.Predef._
import io.gatling.http.Predef._
class ComputerWorld extends Simulation {
val httpProtocol = http
.baseURL("http://computer-database.gatling.io")
.acceptHeader("""text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8""")
.acceptEncodingHeader("""gzip, deflate""")
.acceptLanguageHeader("""en-gb,en;q=0.5""")
.userAgentHeader("""Mozilla/5.0 (Macintosh; Intel Mac OS X 10.9; rv:31.0) Gecko/20100101 Firefox/31.0""")
val computerDbScn = scenario("Computer Scenario")
.exec(http("getComputers")
.get("/computers")
.check(
status is 200,
regex("""\d+ computers found"""),
css("#add", "href").saveAs("addComputer")))
.exec(http("addNewComputer")
.get("${addComputer}")
.check(substring("Add a computer")))
.exec(_.set("homeComputer", s"homeComputer_${ThreadLocalRandom.current.nextInt(Int.MaxValue)}"))
.exec(http("postComputers")
.post("/computers")
.formParam("name", "${homeComputer}")
.formParam("introduced", "2015-10-10")
.formParam("discontinued", "2017-10-10")
.formParam("company", "")
.check(substring("${homeComputer}")))
setUp(computerDbScn.inject(
constantUsersPerSec(2) during(1 minute)
).protocols(httpProtocol))
}
示例10: ComputerWorld
//设置package包名称以及导入依赖的类
package bbc.kraftwerk
import scala.concurrent.duration._
import java.util.concurrent.ThreadLocalRandom
import io.gatling.core.Predef._
import io.gatling.http.Predef._
class ComputerWorld extends Simulation {
val httpProtocol = http
.baseURL("http://computer-database.herokuapp.com")
.acceptHeader("""text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8""")
.acceptEncodingHeader("""gzip, deflate""")
.acceptLanguageHeader("""en-gb,en;q=0.5""")
.contentTypeHeader("application/x-www-form-urlencoded")
.userAgentHeader("""Mozilla/5.0 (Macintosh; Intel Mac OS X 10.9; rv:31.0) Gecko/20100101 Firefox/31.0""")
val computers = http("computers")
.get("/computers")
.check(
status.is(200),
regex("""\d+ computers found"""),
css("#add", "href").saveAs("addComputer"))
val addNewComputer = http("addNewComputer")
.get("${addComputer}")
.check(substring("Add a computer"))
val addNewComputerPost = http("addNewComputerPost")
.post("/computers")
.formParam("name", "${homeComputer}")
.formParam("introduced", "2015-10-10")
.formParam("discontinued", "2017-10-10")
.formParam("company", "")
.check(substring("${homeComputer}"))
val computerDatabaseScn = scenario("computerDatabaseScn")
.exec(_.set("homeComputer", s"homeComputer_${ThreadLocalRandom.current.nextInt(Int.MaxValue)}"))
.exec(computers)
.exec(addNewComputer)
.exec(addNewComputerPost)
setUp(computerDatabaseScn.inject(
constantUsersPerSec(2) during(1 minutes)
).protocols(httpProtocol))
}
示例11: sample
//设置package包名称以及导入依赖的类
package npv
import java.util.concurrent.ThreadLocalRandom
trait Distribution {
def sample(): Double
def getMax(): Double
def getMin(): Double
}
class SingleValueDistribution(value: Double) extends Distribution {
override def sample(): Double = value
override def getMax(): Double = value
override def getMin(): Double = value
}
class TriangleDistribution(min: Double, likely: Double, max: Double)
extends Distribution {
assert(max >= likely)
assert(likely >= min)
val fc: Double = (likely - min) / (max - min)
override def sample(): Double = {
val u = ThreadLocalRandom.current().nextDouble()
if (u < fc) {
min + Math.sqrt(u * (max - min) * (likely - min))
} else {
max - Math.sqrt((1 - u) * (max - min) * (max - likely))
}
}
override def getMin(): Double = min
def getLikely(): Double = likely
override def getMax(): Double = max
}
示例12: ExponentialBackOff
//设置package包名称以及导入依赖的类
package com.snapswap.retry
import java.util.concurrent.ThreadLocalRandom
import scala.concurrent.duration.{Duration, FiniteDuration}
object ExponentialBackOff {
def apply(minBackoff: FiniteDuration, maxBackoff: FiniteDuration, randomFactor: Double): ExponentialBackOff =
new ExponentialBackOff(minBackoff, maxBackoff, randomFactor, 1)
}
case class ExponentialBackOff(protected val minBackoff: FiniteDuration,
protected val maxBackoff: FiniteDuration,
protected val randomFactor: Double,
override val currentAttemptNumber: Int = 1) extends AttemptParams {
require(minBackoff > Duration.Zero, "minBackoff must be > 0")
require(maxBackoff >= minBackoff, "maxBackoff must be >= minBackoff")
require(0.0 <= randomFactor && randomFactor <= 1.0, "randomFactor must be between 0.0 and 1.0")
override def nextAttemptDelay: FiniteDuration = {
val rnd = 1.0 + ThreadLocalRandom.current().nextDouble() * randomFactor
if (currentAttemptNumber >= 30) {
// Duration overflow protection (> 100 years)
maxBackoff
} else {
maxBackoff.min(minBackoff * math.pow(2, currentAttemptNumber.toDouble)) * rnd match {
case f: FiniteDuration ? f
case _ ? maxBackoff
}
}
}
override def nextAttemptParams: ExponentialBackOff = {
copy(currentAttemptNumber = currentAttemptNumber + 1)
}
}
示例13: Unique
//设置package包名称以及导入依赖的类
package org.hyperscala
import java.util.concurrent.ThreadLocalRandom
object Unique {
val LettersLower = "abcdefghijklmnopqrstuvwxyz"
val LettersUpper = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
val Numbers = "0123456789"
val LettersAndNumbers = s"$LettersLower$Numbers"
val AllLettersAndNumbers = s"$LettersLower$LettersUpper$Numbers"
private def r = ThreadLocalRandom.current()
def poolSize(length: Int = 32, characters: String = AllLettersAndNumbers): Long = {
math.pow(characters.length, length).toLong
}
}
示例14: ComputerWorld
//设置package包名称以及导入依赖的类
import scala.concurrent.duration._
import io.gatling.core.Predef._
import io.gatling.http.Predef._
import java.util.concurrent.ThreadLocalRandom
class ComputerWorld extends Simulation {
val httpProtocol = http
.baseURL("http://computer-database.gatling.io")
.acceptHeader("""text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8""")
.acceptEncodingHeader("""gzip, deflate""")
.acceptLanguageHeader("""en-gb,en;q=0.5""")
.contentTypeHeader("application/x-www-form-urlencoded")
.userAgentHeader("""Mozilla/5.0 (Macintosh; Intel Mac OS X 10.9; rv:31.0) Gecko/20100101 Firefox/31.0""")
val computerDbScn = scenario("Computer Scenario")
.exec(http("getComputers")
.get("/computers")
.check(
status is 200,
regex("""\d+ computers found"""),
css("#add", "href").saveAs("addComputer")))
.exec(http("addNewComputer")
.get("${addComputer}")
.check(substring("Add a computer")))
.exec(_.set("homeComputer", s"homeComputer_${ThreadLocalRandom.current.nextInt(Int.MaxValue)}"))
.exec(http("postComputers")
.post("/computers")
.formParam("name", "${homeComputer}")
.formParam("introduced", "2015-10-10")
.formParam("discontinued", "2017-10-10")
.formParam("company", "")
.check(substring("${homeComputer}")))
setUp(computerDbScn.inject(
constantUsersPerSec(2) during(1 minutes)
).protocols(httpProtocol))
}
示例15: DeviceRequest
//设置package包名称以及导入依赖的类
package worker
import java.util.UUID
import java.util.concurrent.ThreadLocalRandom
import scala.concurrent.duration._
import akka.actor.Actor
import akka.actor.ActorLogging
import akka.actor.ActorRef
import com.sandinh.paho.akka._
import com.sandinh.paho.akka.MqttPubSub._
object DeviceRequest {
case object Tick
}
class DeviceRequest(mqttPubSub: ActorRef) extends Actor with ActorLogging {
import DeviceRequest._
import context.dispatcher
def scheduler = context.system.scheduler
def random = ThreadLocalRandom.current
def nextWorkId(): String = UUID.randomUUID().toString
override def preStart(): Unit = scheduler.scheduleOnce(5.seconds, self, Tick)
// override postRestart so we don't call preStart and schedule a new Tick
override def postRestart(reason: Throwable): Unit = ()
def receive = {
case Tick => {
// Random pick from a list of serializable devices
val deviceList: List[Device] = List(new Thermostat, new Lamp, new SecurityAlarm)
val device = deviceList(random.nextInt(0, deviceList.size))
val work = Work(nextWorkId(), device, "Adjust device")
log.info("Device Request -> Device Id {} | Device State {}", device.getId, device.getState)
val payload = MqttConfig.writeToByteArray(work)
log.info("Device Request -> Publishing MQTT Topic {}: Device Id {} | Device State {}", MqttConfig.topic, work.device.getId, work.device.getState)
mqttPubSub ! new Publish(MqttConfig.topic, payload)
context.become(waitAccepted(work, payload), discardOld = false)
}
}
def waitAccepted(work: Work, payload: Array[Byte]): Actor.Receive = {
case IotAgent.Ok =>
context.unbecome()
scheduler.scheduleOnce(random.nextInt(3, 10).seconds, self, Tick)
case IotAgent.NotOk =>
log.info("Device Request -> ALERT: Work Id {} from Device Id {} NOT ACCEPTED, retrying ... ", work.workId, work.device.getId)
scheduler.scheduleOnce(3.seconds, mqttPubSub, new Publish(MqttConfig.topic, payload))
}
}