SynchronousQueue源码中 return (x != null) ? (E)x : e,懂一些,但不是很明白
你说的是E transfer(E e, boolean timed, long nanos)方法的return (x != null) ? (E)x :e;么
* 1. 若队列为空 / 队列中的尾节点和自己的 类型相同, 则添加 node * 到队列中, 直到 timeout/interrupt/其他线程和这个线程匹配 * timeout/interrupt awaitFulfill方法返回的是 node 本身 * 匹配成功的话, 要么返回 null (producer返回的), 或正真的传递值 (consumer 返回的) * * 2. 队列不为空, 且队列的 head.next 节点是当前节点匹配的节点, * 进行数据的传递匹配, 并且通过 advanceHead 方法帮助 先前 block 的节点 dequeue
这个是三元表达式 判断条件 ? 条件成立的返回值 : 条件失败的返回值
比如
a = 1
b = 2
if(a>b){
return a
} else {
return b
}
// 等同于
return a>b ? a : b