本文整理匯總了Java中com.google.common.base.Stopwatch類的典型用法代碼示例。如果您正苦於以下問題:Java Stopwatch類的具體用法?Java Stopwatch怎麽用?Java Stopwatch使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
Stopwatch類屬於com.google.common.base包,在下文中一共展示了Stopwatch類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: verifyActorReady
import com.google.common.base.Stopwatch; //導入依賴的package包/類
@SuppressWarnings("checkstyle:IllegalCatch")
private void verifyActorReady(ActorRef actorRef) {
// Sometimes we see messages go to dead letters soon after creation - it seems the actor isn't quite
// in a state yet to receive messages or isn't actually created yet. This seems to happen with
// actorSelection so, to alleviate it, we use an actorSelection and send an Identify message with
// retries to ensure it's ready.
Timeout timeout = new Timeout(100, TimeUnit.MILLISECONDS);
Throwable lastError = null;
Stopwatch sw = Stopwatch.createStarted();
while (sw.elapsed(TimeUnit.SECONDS) <= 10) {
try {
ActorSelection actorSelection = system.actorSelection(actorRef.path().toString());
Future<Object> future = Patterns.ask(actorSelection, new Identify(""), timeout);
ActorIdentity reply = (ActorIdentity)Await.result(future, timeout.duration());
Assert.assertNotNull("Identify returned null", reply.getRef());
return;
} catch (Exception | AssertionError e) {
Uninterruptibles.sleepUninterruptibly(100, TimeUnit.MILLISECONDS);
lastError = e;
}
}
throw new RuntimeException(lastError);
}
示例2: deleteMapping
import com.google.common.base.Stopwatch; //導入依賴的package包/類
/**
* Removes a range mapping.
*
* @param mapping
* Mapping being removed.
* @param mappingLockToken
* An instance of <see cref="MappingLockToken"/>
*/
public void deleteMapping(RangeMapping mapping,
MappingLockToken mappingLockToken) {
ExceptionUtils.disallowNullArgument(mapping, "mapping");
ExceptionUtils.disallowNullArgument(mappingLockToken, "mappingLockToken");
try (ActivityIdScope activityIdScope = new ActivityIdScope(UUID.randomUUID())) {
log.info("DeleteMapping Start; Shard: {}", mapping.getShard().getLocation());
Stopwatch stopwatch = Stopwatch.createStarted();
this.rsm.remove(mapping, mappingLockToken.getLockOwnerId());
stopwatch.stop();
log.info("DeleteMapping Complete; Shard: {}; Duration: {}", mapping.getShard().getLocation(), stopwatch.elapsed(TimeUnit.MILLISECONDS));
}
}
示例3: verifyShardState
import com.google.common.base.Stopwatch; //導入依賴的package包/類
public static void verifyShardState(final AbstractDataStore datastore, final String shardName,
final Consumer<OnDemandShardState> verifier) throws Exception {
ActorContext actorContext = datastore.getActorContext();
Future<ActorRef> future = actorContext.findLocalShardAsync(shardName);
ActorRef shardActor = Await.result(future, Duration.create(10, TimeUnit.SECONDS));
AssertionError lastError = null;
Stopwatch sw = Stopwatch.createStarted();
while (sw.elapsed(TimeUnit.SECONDS) <= 5) {
OnDemandShardState shardState = (OnDemandShardState)actorContext
.executeOperation(shardActor, GetOnDemandRaftState.INSTANCE);
try {
verifier.accept(shardState);
return;
} catch (AssertionError e) {
lastError = e;
Uninterruptibles.sleepUninterruptibly(50, TimeUnit.MILLISECONDS);
}
}
throw lastError;
}
示例4: initNotificationManager
import com.google.common.base.Stopwatch; //導入依賴的package包/類
private void initNotificationManager() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
final Stopwatch watch = Stopwatch.createStarted();
final NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
final NotificationChannel received = new NotificationChannel(Constants.NOTIFICATION_CHANNEL_ID_RECEIVED,
getString(R.string.notification_channel_received_name), NotificationManager.IMPORTANCE_DEFAULT);
received.setSound(Uri.parse("android.resource://" + getPackageName() + "/" + R.raw.coins_received),
new AudioAttributes.Builder().setContentType(AudioAttributes.CONTENT_TYPE_SONIFICATION)
.setLegacyStreamType(AudioManager.STREAM_NOTIFICATION)
.setUsage(AudioAttributes.USAGE_NOTIFICATION_EVENT).build());
nm.createNotificationChannel(received);
final NotificationChannel ongoing = new NotificationChannel(Constants.NOTIFICATION_CHANNEL_ID_ONGOING,
getString(R.string.notification_channel_ongoing_name), NotificationManager.IMPORTANCE_LOW);
nm.createNotificationChannel(ongoing);
final NotificationChannel important = new NotificationChannel(Constants.NOTIFICATION_CHANNEL_ID_IMPORTANT,
getString(R.string.notification_channel_important_name), NotificationManager.IMPORTANCE_HIGH);
nm.createNotificationChannel(important);
log.info("created notification channels, took {}", watch);
}
}
示例5: getTotalNumByLanguage
import com.google.common.base.Stopwatch; //導入依賴的package包/類
/**
* Returns number of albums according to the specified language.
*
* @param language language code.
* @return number of albums with specified language code.
*/
public long getTotalNumByLanguage(String language) {
return processStore((connection, store) -> {
Stopwatch stopwatch = Stopwatch.createStarted();
QueryCondition languageEqualsCondition = connection.newCondition()
.is("language", QueryCondition.Op.EQUAL, language)
.build();
Query query = connection.newQuery()
.select("_id")
.where(languageEqualsCondition)
.build();
DocumentStream documentStream = store.findQuery(query);
long totalNum = 0;
for (Document ignored : documentStream) {
totalNum++;
}
log.debug("Counting '{}' albums by language '{}' took {}", totalNum, language, stopwatch);
return totalNum;
});
}
示例6: close
import com.google.common.base.Stopwatch; //導入依賴的package包/類
@Override
public void close() throws Exception {
try {
Stopwatch watch = Stopwatch.createStarted();
// this takes 1s to complete
// known issue: https://github.com/netty/netty/issues/2545
eventLoop.shutdownGracefully(0, 0, TimeUnit.SECONDS);
eventLoop.terminationFuture().sync();
long elapsed = watch.elapsed(MILLISECONDS);
if (elapsed > 1200) {
logger.info("closed eventLoopGroups in " + elapsed + " ms");
}
} catch (final InterruptedException e) {
logger.warn("Failure while shutting down bootstrap context event loops.", e);
// Preserve evidence that the interruption occurred so that code higher up on the call stack can learn of the
// interruption and respond to it if it wants to.
Thread.currentThread().interrupt();
}
}
示例7: verifyNodeRemoved
import com.google.common.base.Stopwatch; //導入依賴的package包/類
protected void verifyNodeRemoved(YangInstanceIdentifier path,
Function<YangInstanceIdentifier,NormalizedNode<?,?>> reader) {
AssertionError lastError = null;
Stopwatch sw = Stopwatch.createStarted();
while (sw.elapsed(TimeUnit.MILLISECONDS) <= 5000) {
try {
NormalizedNode<?, ?> node = reader.apply(path);
Assert.assertNull("Node was not removed at path: " + path, node);
return;
} catch (AssertionError e) {
lastError = e;
Uninterruptibles.sleepUninterruptibly(100, TimeUnit.MILLISECONDS);
}
}
throw lastError;
}
示例8: getByUserId
import com.google.common.base.Stopwatch; //導入依賴的package包/類
/**
* Returns list of Artist rates by user identifier.
*
* @param userId user's identifier.
* @return list of Artist rates.
*/
public List<ArtistRate> getByUserId(String userId) {
return processStore((connection, store) -> {
Stopwatch stopwatch = Stopwatch.createStarted();
Query query = connection.newQuery().where(
connection.newCondition()
.is("user_id", QueryCondition.Op.EQUAL, userId)
.build()
).build();
// Fetch all OJAI Documents from this store according to the built query
DocumentStream documentStream = store.findQuery(query);
List<ArtistRate> rates = new ArrayList<>();
for (Document document : documentStream) {
ArtistRate rate = mapOjaiDocument(document);
if (rate != null) {
rates.add(rate);
}
}
log.debug("Get '{}' rates by user id '{}' took {}", rates.size(), userId, stopwatch);
return rates;
});
}
示例9: getByArtistId
import com.google.common.base.Stopwatch; //導入依賴的package包/類
/**
* Returns list of Artist rates by artist identifier.
*
* @param artistId artist's identifier.
* @return list of Artist rates.
*/
public List<ArtistRate> getByArtistId(String artistId) {
return processStore((connection, store) -> {
Stopwatch stopwatch = Stopwatch.createStarted();
Query query = connection.newQuery().where(
connection.newCondition()
.is("document_id", QueryCondition.Op.EQUAL, artistId)
.build()
).build();
// Fetch all OJAI Documents from this store according to the built query
DocumentStream documentStream = store.findQuery(query);
List<ArtistRate> rates = new ArrayList<>();
for (Document document : documentStream) {
ArtistRate rate = mapOjaiDocument(document);
if (rate != null) {
rates.add(rate);
}
}
log.debug("Get '{}' rates by artist id '{}' took {}", rates.size(), artistId, stopwatch);
return rates;
});
}
示例10: getMappings
import com.google.common.base.Stopwatch; //導入依賴的package包/類
/**
* Gets all the range mappings that exist within given range.
*
* @param range
* Range value, any mapping overlapping with the range will be returned.
* @param lookupOptions
* Whether to search in the cache and/or store.
* @return Read-only collection of mappings that satisfy the given range constraint.
*/
public List<RangeMapping> getMappings(Range range,
LookupOptions lookupOptions) {
ExceptionUtils.disallowNullArgument(range, "range");
try (ActivityIdScope activityIdScope = new ActivityIdScope(UUID.randomUUID())) {
log.info("GetMappings Start; Range: {}; Lookup Options: {}", range, lookupOptions);
Stopwatch stopwatch = Stopwatch.createStarted();
List<RangeMapping> rangeMappings = this.rsm.getMappingsForRange(range, null, lookupOptions);
stopwatch.stop();
log.info("GetMappings Complete; Range: {}; Lookup Options: {}; Duration: {}", range, lookupOptions,
stopwatch.elapsed(TimeUnit.MILLISECONDS));
return rangeMappings;
}
}
示例11: getFragments
import com.google.common.base.Stopwatch; //導入依賴的package包/類
/**
* Generate a set of assigned fragments based on the provided fragment tree. Do not allow parallelization stages
* to go beyond the global max width.
*
* @param options Option list
* @param foremanNode The driving/foreman node for this query. (this node)
* @param queryId The queryId for this query.
* @param activeEndpoints The list of endpoints to consider for inclusion in planning this query.
* @param reader Tool used to read JSON plans
* @param rootFragment The root node of the PhysicalPlan that we will be parallelizing.
* @param session UserSession of user who launched this query.
* @param queryContextInfo Info related to the context when query has started.
* @return The list of generated PlanFragment protobuf objects to be assigned out to the individual nodes.
* @throws ExecutionSetupException
*/
public List<PlanFragment> getFragments(
OptionList options,
NodeEndpoint foremanNode,
QueryId queryId,
Collection<NodeEndpoint> activeEndpoints,
PhysicalPlanReader reader,
Fragment rootFragment,
UserSession session,
QueryContextInformation queryContextInfo,
FunctionLookupContext functionLookupContext) throws ExecutionSetupException {
observer.planParallelStart();
final Stopwatch stopwatch = Stopwatch.createStarted();
final PlanningSet planningSet = getFragmentsHelper(activeEndpoints, rootFragment);
observer.planParallelized(planningSet);
stopwatch.stop();
observer.planAssignmentTime(stopwatch.elapsed(TimeUnit.MILLISECONDS));
stopwatch.start();
List<PlanFragment> fragments = generateWorkUnit(options, foremanNode, queryId, reader, rootFragment, planningSet, session, queryContextInfo, functionLookupContext);
stopwatch.stop();
observer.planGenerationTime(stopwatch.elapsed(TimeUnit.MILLISECONDS));
observer.plansDistributionComplete(new QueryWorkUnit(fragments));
return fragments;
}
示例12: update
import com.google.common.base.Stopwatch; //導入依賴的package包/類
/**
* {@inheritDoc}
*
* @param id identifier of document, which will be updated.
* @param albumRate album rate.
* @return updated album rate.
*/
@Override
public AlbumRate update(String id, AlbumRate albumRate) {
return processStore((connection, store) -> {
Stopwatch stopwatch = Stopwatch.createStarted();
// Create a DocumentMutation to update non-null fields
DocumentMutation mutation = connection.newMutation();
// Update only non-null fields
if (albumRate.getRating() != null) {
mutation.set("rating", albumRate.getRating());
}
// Update the OJAI Document with specified identifier
store.update(id, mutation);
Document updatedOjaiDoc = store.findById(id);
log.debug("Update document from table '{}' with id: '{}'. Elapsed time: {}", tablePath, id, stopwatch);
// Map Ojai document to the actual instance of model class
return mapOjaiDocument(updatedOjaiDoc);
});
}
示例13: createPointMapping
import com.google.common.base.Stopwatch; //導入依賴的package包/類
/**
* Creates and adds a point mapping to ShardMap.
*
* @param point
* Point for which to create the mapping.
* @param shard
* Shard associated with the point mapping.
* @return Newly created mapping.
*/
public PointMapping createPointMapping(KeyT point,
Shard shard) {
ExceptionUtils.disallowNullArgument(shard, "shard");
try (ActivityIdScope activityIdScope = new ActivityIdScope(UUID.randomUUID())) {
PointMappingCreationInfo args = new PointMappingCreationInfo(point, shard, MappingStatus.Online);
String mappingKey = args.getKey().toString();
log.info("CreatePointMapping Start; ShardMap name: {}; Point Mapping: {}", this.getName(), mappingKey);
Stopwatch stopwatch = Stopwatch.createStarted();
PointMapping pointMapping = lsm.add(new PointMapping(this.getShardMapManager(), args));
stopwatch.stop();
log.info("CreatePointMapping Complete; ShardMap name: {}; Point Mapping: {}; Duration: {}", this.getName(), mappingKey,
stopwatch.elapsed(TimeUnit.MILLISECONDS));
return pointMapping;
}
}
示例14: testFull
import com.google.common.base.Stopwatch; //導入依賴的package包/類
private void testFull(QueryType type, String planText, String filename,
int numberOfTimesRead /* specified in json plan */,
int numberOfRowGroups, int recordsPerRowGroup, boolean testValues) throws Exception {
// final RecordBatchLoader batchLoader = new RecordBatchLoader(getAllocator());
final HashMap<String, FieldInfo> fields = new HashMap<>();
final ParquetTestProperties props =
new ParquetTestProperties(numberRowGroups, recordsPerRowGroup, DEFAULT_BYTES_PER_PAGE, fields);
TestFileGenerator.populateFieldInfoMap(props);
final ParquetResultListener resultListener =
new ParquetResultListener(getAllocator(), props, numberOfTimesRead, testValues);
final Stopwatch watch = Stopwatch.createStarted();
testWithListener(type, planText, resultListener);
resultListener.getResults();
// batchLoader.clear();
System.out.println(String.format("Took %d ms to run query", watch.elapsed(TimeUnit.MILLISECONDS)));
}
示例15: deleteMapping
import com.google.common.base.Stopwatch; //導入依賴的package包/類
/**
* Removes a point mapping.
*
* @param mapping
* Mapping being removed.
*/
public void deleteMapping(PointMapping mapping) {
ExceptionUtils.disallowNullArgument(mapping, "mapping");
try (ActivityIdScope activityIdScope = new ActivityIdScope(UUID.randomUUID())) {
String mappingKey = mapping.getKey().getRawValue().toString();
log.info("DeletePointMapping Start; ShardMap name: {}; Point Mapping: {}", this.getName(), mappingKey);
Stopwatch stopwatch = Stopwatch.createStarted();
lsm.remove(mapping);
stopwatch.stop();
log.info("DeletePointMapping Completed; ShardMap name: {}; Point Mapping: {}; Duration: {}", this.getName(), mappingKey,
stopwatch.elapsed(TimeUnit.MILLISECONDS));
}
}