我了解到Advanced_For_Loop可以使用两个表达式。 当它有三个时,我不知道它是如何工作的。我的意思是:for(expression1:expression2:expression3)。 而且我不知道它在这段代码中如何迭代...
private Sheet fieldVsTime(Workbook wb, String _title,List<PivotField>
_pivots, List<PivotField> _all,boolean _periods,Map<String, String>
_yAxesMapping) {
for (PivotField pivot : _all == null ? _pivots : _all) {
List<PivotField> list = pivot.getPivot();
if (list != null) {
for (PivotField pivotField : list) {
int publishDate = Integer.parseInt(pivotField.getValue().toString());
if (_periods) {
publishDate = (publishDate / 10) * 10;
}
if (publishDate < minYear) {
minYear = publishDate;
}
if (publishDate > maxYear) {
maxYear = publishDate;
}
}
}
}
答案 0 :(得分:11)
它只有两个表达式:
for (PivotField pivot : (_all == null ? _pivots : _all))
---------------- -------------------------------
1 2
第二个表达式(_all == null ? _pivots : _all)
会返回_pivots
或_all
,具体取决于_all == null
。
答案 1 :(得分:4)
相当于此代码:
List<PivotField> pivotFields;
if( _all == null ) {
pivotFields = _pivots;
}
else {
pivotFields = _all;
}
for (PivotField pivot : pivotFields) {
...
}