Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

remove an event from eventqueue #369

Open
Cattttw opened this issue Apr 26, 2021 · 6 comments
Open

remove an event from eventqueue #369

Cattttw opened this issue Apr 26, 2021 · 6 comments

Comments

@Cattttw
Copy link

Cattttw commented Apr 26, 2021

Summary

when I remove an event from an eventqueue ,will the changes still be made

Description

in the Main class, I defined an eventqueue, which is all the event (Like Arrive, Serve). If I first add an event in it, then I realised that this event is not right ,so I remove this event from the eventqueue. In the event, I made some changes to the server or customer. If I remove the event, will these changes still be made or these changes are also removed?

Screenshots (if any):

Insert Images here if necessary

@OuaisBien
Copy link

don't think so. You should manually reverse the changes. But if your incorrect event stems from server resting, simply rescheduling an event would be just fine.

@e0560113
Copy link

it sounds like the changes will still be made, but it depends on how your server/customer is stored

@downmeanhigh
Copy link

it really depends on how you implement your events, but if I understand correctly the changes will not be made

@zhuoyunhui
Copy link

it most probably won't undo the changes you made to the state of the servers, so you'll probably have to manually undo the changes everytime you remove an event

@JWulaXia
Copy link

i suggest you only add in event that is confirmed, such as you add the done event after you finish the serve event, since the event are in a priority queue and they are hard to remove. in my structure, I first use the arrive event and check the servers' availability and decide to use wait/serve event. all these events are stored in the priority queue which has a compareTo() method to compare.

@lohwenxin
Copy link

I

i suggest you only add in event that is confirmed, such as you add the done event after you finish the serve event, since the event are in a priority queue and they are hard to remove. in my structure, I first use the arrive event and check the servers' availability and decide to use wait/serve event. all these events are stored in the priority queue which has a compareTo() method to compare.

Yes, agree as if you schedule the event already in PriorityQueue, it is hard to remove it from the queue before it is being printing. If you increment the Statistics according to each event being scheduled, it will affect the data to be printed out at the end as well. Not scheduling it if it is not meant to be served seems to be the better way. You can try not returning serve from wait, but returning serve after the previous customer rests!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

7 participants