Micro-optimize loop.

This commit is contained in:
Vladimir Mihailenco 2012-08-20 11:40:27 +03:00
parent 583e901221
commit 5e2cce4853
2 changed files with 7 additions and 8 deletions

View File

@ -82,14 +82,11 @@ func (c *MultiClient) ExecReqs(reqs []Req, conn *Conn) error {
statusReq := NewStatusReq()
// Parse MULTI command reply.
_, err = statusReq.ParseReply(conn.Rd)
if err != nil {
return err
}
// Omit last request (EXEC).
reqsLen := len(reqs) - 1
// Parse queued replies.
for i := 1; i < len(reqs)-1; i++ {
for i := 0; i < reqsLen; i++ {
_, err = statusReq.ParseReply(conn.Rd)
if err != nil {
return err
@ -109,7 +106,8 @@ func (c *MultiClient) ExecReqs(reqs []Req, conn *Conn) error {
}
// Parse replies.
for i := 1; i < len(reqs)-1; i++ {
// Loop starts from 1 to omit first request (MULTI).
for i := 1; i < reqsLen; i++ {
req := reqs[i]
val, err := req.ParseReply(conn.Rd)
if err != nil {

View File

@ -67,7 +67,8 @@ func (c *PipelineClient) RunReqs(reqs []Req, conn *Conn) error {
return err
}
for i := 0; i < len(reqs); i++ {
reqsLen := len(reqs)
for i := 0; i < reqsLen; i++ {
req := reqs[i]
val, err := req.ParseReply(conn.Rd)
if err != nil {