Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/350.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
我的JavaFx应用程序运行非常缓慢_Java_Performance_Javafx - Fatal编程技术网

我的JavaFx应用程序运行非常缓慢

我的JavaFx应用程序运行非常缓慢,java,performance,javafx,Java,Performance,Javafx,我正在做一个连接到documentum数据存储的JavaFx项目。最近我注意到,在某些特定点上,它的执行速度相当慢。一旦开始运行,它将从documentum中检索一些数据,考虑到数据量,这一速度相当快,并创建我定义的类的实例,以便将它们加载到表中。到目前为止还可以。以下是我的功能: public void createCheckbox() { List<String> columnnames = Arrays.asList("id", "name", "bg", "c

我正在做一个连接到documentum数据存储的JavaFx项目。最近我注意到,在某些特定点上,它的执行速度相当慢。一旦开始运行,它将从documentum中检索一些数据,考虑到数据量,这一速度相当快,并创建我定义的类的实例,以便将它们加载到表中。到目前为止还可以。以下是我的功能:

public void createCheckbox() {
        List<String> columnnames = Arrays.asList("id", "name", "bg", "country","countryCode", "status",
                "incorporationDate","aclName","aclDomain");
        for (int i = 0; i <= columnnames.size() - 1  ; i++) {
            ColumnConstraints column1 = new ColumnConstraints();
            column1.setPercentWidth(22.0);

            gridChkBoxContainer.getColumnConstraints().add(column1);
            CheckBox cbs = new CheckBox(columnnames.get(i));
            cbs.selectedProperty().set(true);
            gridChkBoxContainer.add(cbs, i, 0);
        }
    }


    public void createTable() {
        int count = 0 ;
        infoTable.getColumns().clear();
        CheckBox cb;
        ObservableList<Node> childrens = gridChkBoxContainer.getChildren();
        for (Node node : childrens) {
            cb = (CheckBox) node;
            if (cb.isSelected()) {
                TableColumn Col = new TableColumn(cb.getText());
                Col.prefWidthProperty().bind(infoTable.widthProperty().divide(6));
                Col.setCellValueFactory(new PropertyValueFactory<Report, String>(cb.getText()));
                infoTable.getColumns().add(Col);
            }
        }

        try{
            infoTable.getItems().clear();
            if (txtKeyword.getText().compareTo("") == 0){


            strDQL = "select dm_dbo.cosec_general_view.name , dm_dbo.cosec_general_view.comp_id , dm_dbo.cosec_general_view.bg_name , dm_dbo.cosec_general_view.incorporation_date , dm_dbo.cosec_general_view.status , dm_dbo.cosec_general_view.country_name , cosec_general.acl_domain , cosec_general.acl_name , cosec_general.country_code from dm_dbo.cosec_general_view , cosec_general where dm_dbo.cosec_general_view.comp_id =cosec_general.comp_id";
            }else{
                strDQL = "select dm_dbo.cosec_general_view.name , dm_dbo.cosec_general_view.comp_id , dm_dbo.cosec_general_view.bg_name , dm_dbo.cosec_general_view.incorporation_date , dm_dbo.cosec_general_view.status , dm_dbo.cosec_general_view.country_name , cosec_general.acl_domain , cosec_general.acl_name , cosec_general.country_code from dm_dbo.cosec_general_view , cosec_general where dm_dbo.cosec_general_view.comp_id =cosec_general.comp_id and ( UPPER(dm_dbo.cosec_general_view.comp_id) like UPPER('@aclname') or  UPPER(dm_dbo.cosec_general_view.name) like UPPER('@aclname')or  UPPER(dm_dbo.cosec_general_view.bg_name) like UPPER('@aclname') or  UPPER(dm_dbo.cosec_general_view.incorporation_date) like UPPER('@aclname')  or  UPPER(dm_dbo.cosec_general_view.country_name) like UPPER('@aclname')  or  UPPER(dm_dbo.cosec_general_view.status) like UPPER('@aclname') or  UPPER(cosec_general.acl_name) like UPPER('@aclname')or  UPPER(cosec_general.acl_domain) like UPPER('@aclname')or  UPPER(cosec_general.country_code) like UPPER('@aclname') )";

                String searchVar = "%"+txtKeyword.getText()+"%";
                strDQL = strDQL.replace("@aclname", searchVar );

            }
            IDfQuery ACLQuery = new DfQuery();
            ACLQuery.setDQL(strDQL);
            IDfCollection col = ACLQuery.execute(_session, DfQuery.DF_READ_QUERY);
            while (col.next()) {
                BGDetails bgInfo = new BGDetails(col.getString("comp_id"), col.getString("name"), col.getString("bg_name"),
                        col.getString("country_name"), col.getString("status"), col.getString("incorporation_date"),col.getString("acl_name"),col.getString("acl_domain"),col.getString("country_code"));

                infoTable.getItems().add(bgInfo);
                count++;

            }}catch(Exception e){
                Alert alert = new Alert (Alert.AlertType.ERROR , "An Error was found!");
                alert.showAndWait();
            }


    if (count == 0 ){
        Alert alert = new Alert(Alert.AlertType.WARNING , "No search result was found !");
        alert.showAndWait();

    }
    }
然后在顶部有文本字段fx:id=txtKeyword,用于搜索数据。值得一提的是,为了达到这个目的,我将创建并定制一个新的DQL,以再次从数据存储中重新获取数据,而不是存储我之前获取的数据。我注意到,在这一点上,不是数据检索需要很长时间才能运行,而是在搜索字段中键入单词明显滞后。或者换句话说,每次我想用键盘或鼠标在应用程序中导航时,它都会开始滞后,其他时间都可以。你知道如何提高性能的速度吗?
提前感谢:

任何与JavaFX线程无关的事情都可以在外部线程上完成,尤其是数据库查询

JavaFX服务的示例结构下面是使用SQLITE的示例:


您声明在文本字段中键入时会出现性能问题-执行此操作时会运行哪些代码?大概你已经注册了一些ChangeListener?还是每次更改文本时都会调用createTable方法?@sillyfly一旦我单击文本字段txtKeyword触发它输入一些文本,它就会滞后,换句话说,文本字段需要一段时间才能理解我单击了它,而当我使用键盘将数据插入到该文本字段时,显示器总是离我很远在我身后,考虑到我的打字速度没有那么快:D我理解这一部分,我想问的是——每次按键/文本字段中文本的每次更改都会调用代码的哪一部分?是createTable方法吗?或者问题中未包含的其他代码?
public class DataLoader extends Service<Boolean> {

    int total;

    /**
     * Constructor
     */
    public DataLoader() {

        // if succeeded
        setOnSucceeded(s -> {
            //code if Service succeeds
        });

        // if failed
        setOnFailed(fail -> {
            //code it Service fails
        });

        //if canceled
        setOnCancelled(cancelled->{
            //code if Service get's cancelled
        });
    }

    @Override
    protected Task<Boolean> createTask() {
        return new Task<Boolean>() {
            @Override
            protected Void call() throws Exception {

                // -------------------------- Load all the libraries
                try (ResultSet resultSet = connection1.createStatement().executeQuery("SELECT* FROM LIBRARIES;");
                        ResultSet dbCounter = connection1.createStatement()
                                .executeQuery("SELECT COUNT(*) FROM LIBRARIES;");) {

                    total = dbCounter.getInt(1);
                    Main.logger.info("Uploading libraries....");

                    // Refresh the text
                    Platform.runLater(() -> Main.updateScreen.label.setText("Uploading Libraries..."));
                    updateProgress(1, 2);

                    // Load all the libraries
                    while (resultSet.next()) {

                        Library library = new Library(resultSet.getString("NAME"), resultSet.getString("TABLENAME"),
                                resultSet.getDouble("STARS"), resultSet.getString("DATECREATED"),
                                resultSet.getString("TIMECREATED"), resultSet.getString("DESCRIPTION"),
                                resultSet.getInt("SAVEMODE"), resultSet.getInt("POSITION"),
                                resultSet.getString("LIBRARYIMAGE"), resultSet.getBoolean("OPENED"));

                        //Using Platform Later to Modify JavaFX Nodes
                        Platform.runLater(()->{
                           //code here
                        });

                        updateProgress(resultSet.getRow(), total);
                    }

                } catch (Exception ex) {
                    Main.logger.log(Level.SEVERE, "", ex);
                    return false //something bad happened
                }

                return true;
            }
        };
    }

}