Reflect is just too slow
After reducing collision objects in previous article and optimize memory usage, I think it is time to do some pressure test. So the entire scene is frozen when spawning 1440 bullets. The profile info looks like:
data:image/s3,"s3://crabby-images/3e0cb/3e0cb388d07235317be8391f0a576738ac8dc5a8" alt=""
The profile shows that every access operation rely on ‘Type.getClassName’ function, because Entity object uses [Class => value] Map to store components in traditional ECS framework. But Reflect is very slow, it takes 18% execution time just for adding components to Entity. There is second part:
data:image/s3,"s3://crabby-images/ae6e8/ae6e85cff169009a03a54c55a95fc184d20b8013" alt=""
Because Bullet Entity use a internal finite state machine to manage components, it still use Reflect. After counting each state, I find ‘Type.getClassName’ function takes about 40% of execution time just for access components. When creating lots of entity, the fps will decrease to 1 and hurt user experience.
So I have to use new approach: using flyweight pattern to store components and accessed by Entity id.
It requires refactoring all codes that adding / checking / removnig components, but still worth it:
data:image/s3,"s3://crabby-images/83ce0/83ce09eafc8f4d2fc8e0a2cae792d0fd7856405c" alt=""
FPS increases form 1 to 22 in deep profile mode, and 130 when closing profile. Now I can say:
data:image/s3,"s3://crabby-images/37317/37317784fbfeaa275dfbd224b455d5122ac4dcca" alt=""