实战演示:如何在Java中运用Verify类
最编程
2024-08-05 18:00:01
...
实例1: TypevarContext
import com.google.common.base.Verify; //导入依赖的package包/类
TypevarContext(TypeElement element, String renderedTypeString) {
List<? extends TypeParameterElement> typeParameters = element.getTypeParameters();
if (!typeParameters.isEmpty()) {
this.arguments = SourceTypes.extract(renderedTypeString).getValue();
this.parameters = Lists.newArrayList();
for (TypeParameterElement p : typeParameters) {
parameters.add(p.getSimpleName().toString());
}
// we allow having no arguments in a string as raw type/unspecified argument scenario
Verify.verify(arguments.isEmpty() || (parameters.size() == arguments.size()), parameters + " =/> " + arguments);
} else {
this.parameters = Collections.emptyList();
this.arguments = Collections.emptyList();
}
}
实例2: signature
import com.google.common.base.Verify; //导入依赖的package包/类
private boolean signature(Statement.Builder builder) {
Term t = terms.peek();
if (t.is("@")) {
do {
builder.addAnnotations(terms.next());
Verify.verify(terms.peek().isWordOrNumber());
builder.addAnnotations(terms.next());
} while (terms.peek().is("."));
if (terms.peek().is("(")) {
builder.addAllAnnotations(collectUntilMatching(")"));
}
return false;
} else if (t.is("<")) {
builder.addAllSignature(collectUntilMatching(">"));
return false;
} else if (t.is("class")) {
builder.addSignature(terms.next());
return true;
} else {
builder.addSignature(terms.next());
return false;
}
}
实例3: await
import com.google.common.base.Verify; //导入依赖的package包/类
/** Waits for the supplier to return a present value. */
private <T> T await(Supplier<Optional<T>> compute) throws IOException {
AtomicReference<T> result = new AtomicReference<>();
BooleanSupplier condition =
() -> {
Optional<T> value = compute.get();
if (value.isPresent()) {
result.set(value.get());
}
return value.isPresent();
};
try {
monitor.enterWhen(monitor.newGuard(condition));
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
throw new IOException(e);
}
try {
return Verify.verifyNotNull(result.get());
} finally {
monitor.leave();
}
}
实例4: from
import com.google.common.base.Verify; //导入依赖的package包/类
/**
* Classifies an identifier's case format.
*/
static JavaCaseFormat from(String name) {
Verify.verify(!name.isEmpty());
boolean firstUppercase = false;
boolean hasUppercase = false;
boolean hasLowercase = false;
boolean first = true;
for (int i = 0; i < name.length(); i++) {
char c = name.charAt(i);
if (!Character.isAlphabetic(c)) {
continue;
}
if (first) {
firstUppercase = Character.isUpperCase(c);
first = false;
}
hasUppercase |= Character.isUpperCase(c);
hasLowercase |= Character.isLowerCase(c);
}
if (firstUppercase) {
return hasLowercase ? UPPER_CAMEL : UPPERCASE;
} else {
return hasUppercase ? LOWER_CAMEL : LOWERCASE;
}
}
上一篇: Java检测单选按钮状态与复选框选中情况
下一篇: 实战演练:Java文件操作练习题
推荐阅读
-
实战演示:如何在Java中运用JGraphXAdapter类
-
实战演示:如何在Java中运用Verify类
-
TypeScript实战笔记:详解类与泛型的运用实例,学习如何在TypeScript中玩转泛型,及其在提升代码灵活性与安全性的角色 - 青训营教程
-
实操演示:Java中Cosine相似度计算类的运用示例
-
【2022新手指南】Java编程进阶之路 - 六、技术架构篇 ### MySQL索引底层解析与优化实战 - 你会讲解MySQL索引的数据结构吗?性能调优技巧知多少? - Redis深度揭秘:你知道多少?从基础到哨兵、主从复制全梳理 - Redis持久化及哨兵模式详解,还有集群搭建和Leader选举黑箱打开 - Zookeeper是个啥?特性和应用场景大公开 - ZooKeeper集群搭建攻略及 Leader选举、读写一致性、共享锁实现细节 - 探究ZooKeeper中的Leader选举机制及其在分布式环境中的作用 - Zab协议深入剖析:原理、功能与在Zookeeper中的核心地位 - RabbitMQ全方位解读:工作模式、消费限流、可靠投递与配置策略 - 设计者视角:RabbitMQ过期时间、死信队列与延时队列实践指南 - RocketMQ特性和应用场景揭示:理解其精髓与差异化优势 - Kafka详细介绍:特性及广泛应用于实时数据处理的场景解析 - ElasticSearch实力揭秘:特性概述与作为搜索引擎的广泛应用 - MongoDB认知升级:非关系型数据库的优势阐述,安装与使用实战教学 - BIO/NIO/AIO网络模型对比:掌握它们的区别与在网络编程中的实际应用 - Netty带你飞:理解其超快速度背后的秘密,包括线程模型分析 - 网络通信黑科技:Netty编解码原理与常用编解码器的应用,Protostuff实战演示 - 解密Netty粘包与拆包现象,怎样有效应对这一常见问题 - 自定义Netty心跳检测机制,轻松调整检测间隔时间的艺术 - Dubbo轻骑兵介绍:核心特性概览,服务降级实战与其实现益处 - Dubbo三大神器解读:本地存根与本地伪装的实战运用与优势呈现 ----------------------- 七、结语与回顾
-
实例演示:在Java中运用CollectionType类
-
实操演示:Java中HttpParams类的运用实例
-
实战教程:在Java Swing中运用下拉菜单、弹出菜单和选项卡界面的实例演示
-
实战演示:如何在Java中运用JBTable类
-
实战演示:如何在Java中运用JFontChooser类