首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Vaadin惰性加载网格错误: java.lang.IndexOutOfBoundsException:索引0超出长度0的界限

Vaadin惰性加载网格错误: java.lang.IndexOutOfBoundsException:索引0超出长度0的界限
EN

Stack Overflow用户
提问于 2021-04-09 16:53:27
回答 1查看 112关注 0票数 1

我试图在vaadin网格上进行延迟加载,但是我得到了错误java.lang.IndexOutOfBoundsException: Index 0 out of bounds for length 0,这是我的UI代码:

代码语言:javascript
运行
复制
// Grid Account
Grid<AccountModel> accountData = new Grid<>(AccountModel.class);
CallbackDataProvider<AccountModel, Void> accountDataProvider = DataProvider
        .fromCallbacks(
                query -> {
                    System.out.println("Offset :");
                    System.out.println(query.getOffset());
                    System.out.println("Limit :");
                    System.out.println(query.getLimit());
                    System.out.println("End Offset, Limit");
                    return accountServices.getAccountTableWithParam(query.getOffset(), query.getLimit()).stream();
                },
                query -> {
                    System.out.println("Count :");
                    int count = 0;
                    try {
                        count = accountServices.getAccountTableCount();
                    } catch (EndpointException ex) {
                        Logger.getLogger(AccountServices.class.getName()).log(Level.SEVERE, null, ex);
                    }
                    System.out.println(count);
                    System.out.println("END BRO");
                    return count;
                });

accountData.setDataProvider(accountDataProvider);
accountData.setColumns("accountId", "name", "balance", "allowNegativeBalance");       
add(accountData);

下面是我的服务代码:

代码语言:javascript
运行
复制
public List<AccountModel> getAccountTableWithParam(Integer limit, Integer offset) {
    List<AccountModel> datalog = null;
    try {
        datalog = new JsonResponseReader(restMockvaEndpoint.send(new EndpointRequestBuilder()
                .method("GET")
                .resource("/account")
                .property("offset", offset)
                .property("limit", limit)
                .build())).getContentTable(AccountModel.class).getData();
    } catch (EndpointException ex) {
        Logger.getLogger(AccountServices.class.getName()).log(Level.SEVERE, null, ex);
    }
    return datalog;
}

public int getAccountTableCount() throws EndpointException {
    int datalog = new JsonResponseReader(restMockvaEndpoint.send(new EndpointRequestBuilder()
                .method("GET")
                .resource("/account")
                .build()
        )).getContentTable(AccountModel.class).getData().size();
    return datalog;
}

下面是Wildfly Log:

代码语言:javascript
运行
复制
15:45:05,977 INFO  [org.eclipse.jetty.util.log] (default task-2) Logging initialized @964386ms to org.eclipse.jetty.util.log.Slf4jLog
15:45:06,157 INFO  [stdout] (default task-2) Count :
15:45:06,284 INFO  [stdout] (default task-2) 2
15:45:06,284 INFO  [stdout] (default task-2) END BRO
15:45:06,284 INFO  [stdout] (default task-2) Offset :
15:45:06,284 INFO  [stdout] (default task-2) 0
15:45:06,284 INFO  [stdout] (default task-2) Limit :
15:45:06,285 INFO  [stdout] (default task-2) 2
15:45:06,285 INFO  [stdout] (default task-2) End Offset, Limit
15:45:06,292 INFO  [stdout] (default task-2) Count :
15:45:06,300 INFO  [stdout] (default task-2) 2
15:45:06,300 INFO  [stdout] (default task-2) END BRO
15:45:06,303 ERROR [com.vaadin.flow.server.DefaultErrorHandler] (default task-2) : java.lang.IndexOutOfBoundsException: Index 0 out of bounds for length 0
    at java.base/jdk.internal.util.Preconditions.outOfBounds(Preconditions.java:64)
    at java.base/jdk.internal.util.Preconditions.outOfBoundsCheckIndex(Preconditions.java:70)
    at java.base/jdk.internal.util.Preconditions.checkIndex(Preconditions.java:248)
    at java.base/java.util.Objects.checkIndex(Objects.java:372)
    at java.base/java.util.ArrayList.get(ArrayList.java:459)
    at deployment.TES-PROJECT-1.war//com.vaadin.flow.data.provider.DataCommunicator.lambda$getJsonItems$3(DataCommunicator.java:615)
    at java.base/java.util.stream.IntPipeline$1$1.accept(IntPipeline.java:180)
    at java.base/java.util.stream.Streams$RangeIntSpliterator.forEachRemaining(Streams.java:104)
    at java.base/java.util.Spliterator$OfInt.forEachRemaining(Spliterator.java:699)
    at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:484)

有什么想法吗?谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-05-19 11:21:38

请检查计数变量,确保计数不受偏移量和限制的影响

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67018013

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档