Your second example is close, but you want to call ReadKey with a -1 instead of a 0, to tell Term::ReadKey not to block and wait for a key.

What you may want to consider though, is that by running in a tight loop like this you are going to suck up CPU time in a big way. For your purposes (collecting random data presumably from keystroke timings), you would probably be better of intentionally blocking and just keeping track of the times between the keystrokes, which would be much less CPU intensive.