Comments (3)
Good question. The hashing of the string is actually more expensive than just comparing it with the names.
Now we all learned that hash map lookups are O(1) and the comparing is O(n), but in this case n is very small, since n is just the number of parameters in the matched URL pattern. I can't think of a good URL structure with n ≥ 10, usually it is just 0 ≤ n ≤ 3.
And the hash map lookup is actually O(1+c), where c is a quite big constant in this case.
Moreover hash maps need a lot more memory.
The router initially used maps ;)
from httprouter.
@julienschmidt So glad you addressed the O(1) vs O(n). Great answer!
I had no idea about O(1+c) (for hash maps) probably being greater than O(n) where n is usually 0 ≤ n ≤ 3.
Are all hash maps usually a large c constant and O(1+c) or is this just a thing in Go?
Just curious. Thanks!
from httprouter.
@julienschmidt I noticed that Brad Fitzpatrick suggested using an array instead of a map for part of the HTTP2 golang implementation. Probably because that particular map only contains 10 elements. I wonder what the performance cutoff is in go for maps?
https://www.youtube.com/watch?v=gAfoLwog_MA&feature=youtu.be&t=21m18s
Well played!
from httprouter.
Related Issues (20)
- How to use this custom middleware HOT 1
- Matching multiple named parameters HOT 1
- ServeFiles not able to serve static files HOT 2
- How can I receive multiple parameters in GET request? HOT 3
- Is it possible to bind one router to some path in another router? HOT 2
- is it possible to get the registered path? HOT 10
- panic: '/hello/:name' in new path '/hello/:name' conflicts with existing wildcar
- Why make catchAll form so special HOT 2
- httprouter.ParamsWithContext(r.Context()) is returning []
- Question: will re-registering a handler work properly?
- Fails with "embed" package HOT 4
- Dump all registered routes HOT 3
- Improve longestCommonPrefix and add unit tests HOT 1
- Question: How can I embed swagger UI? HOT 2
- Feature Request: Support multi-wildcard names for same tree branch HOT 1
- panic: path must begin with '/' in path 'GET'
- List all registered endpoint httprouter
- what is the empty path node used for? HOT 1
- Unable to load jsx files because "file.jsx was blocked because of a disallowed MIME type text/plain" HOT 2
- Plan to Consolidate with net/http @ 1.22? HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from httprouter.