You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I did some experimentation: I commented out the deep copying code in the Util.java class:
protected static Object deepCopy(Object fromBean) {
// ByteArrayOutputStream bos = new ByteArrayOutputStream();
// XMLEncoder out = new XMLEncoder(bos);
// out.writeObject(fromBean);
// out.close();
//
// ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
// XMLDecoder in = new XMLDecoder(bis, null, null, JsonDBTemplate.class.getClassLoader());
// Object toBean = in.readObject();
// in.close();
// return toBean;
return fromBean;
}
Then I ran my application and it seems that there was no negative impact and after calling the JsonDBTemplate constructor for the first time, all other db calls where extremely fast!
My questions are:
What is the benefit (or considerations) for doing the deep copying?
NOT doing the deep copying - what problems may it cause, if any?
I would like to gain more insight into when the json data files are loaded into memory: when calling the JsonDBTemplate constructor for the first time, does it load ALL the json data files into memory to cache the collections up-front?
Again, I love your DB and I look forward to hear your answers!
The text was updated successfully, but these errors were encountered:
Deep copying was done so that the objects in memory would be disconnected from the objects returned by the various query method.
Not doing deep copy has one side effect, once you have queried and obtained object(s) from the JsonDB you can then change the contents of that object and those changes would also be done in the JsonDB memory, this would not be issue normally, however, it might cause subtle bugs especially in case of the update methods. You might end up assuming that I have changed the object and it is all done however the change will not be written to the files. This would mean data in cache is out of sync with data in the files. However, if you continue to invoke the update methods without fail you can choose not to do deep copy and it should all work fine.
Data files can be loaded in 2 ways. a) at the time of constructor invocation everything in data folder is loaded up front. b) you can invoke reload() method to load a particular collection again on demand. You can also register for event listners (though they don't work on mac) and reload based on events received when underlying data files change
I do not plan to change this behaviour at the moment. In future if time permits i can try and make it configurable, until then i am going to mark it wont fix
Hi Farooq,
I really love jsondb.io !!!
I did some experimentation: I commented out the deep copying code in the Util.java class:
protected static Object deepCopy(Object fromBean) {
// ByteArrayOutputStream bos = new ByteArrayOutputStream();
// XMLEncoder out = new XMLEncoder(bos);
// out.writeObject(fromBean);
// out.close();
//
// ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
// XMLDecoder in = new XMLDecoder(bis, null, null, JsonDBTemplate.class.getClassLoader());
// Object toBean = in.readObject();
// in.close();
// return toBean;
return fromBean;
}
Then I ran my application and it seems that there was no negative impact and after calling the JsonDBTemplate constructor for the first time, all other db calls where extremely fast!
My questions are:
Again, I love your DB and I look forward to hear your answers!
The text was updated successfully, but these errors were encountered: