dongzheng8463 2017-11-28 13:50
浏览 100


I'm coming across a few situations where I would like to use routing to change some Is_Active fields in my database but I'm curious about performance.

Let's have a route handler as so:

func testHandler(r *mux.Router) {
    r.HandleFunc("/test/{status}" statusHandler).Methods("GET")

Now that parameter will only ever be 0 or 1, unless the user tries something else but either way nothing will happen unless it's 0 or 1. My question is, is it faster to parse the string into a boolean which would involve bringing in the strconv package or would it be faster to just do a switch on the string?

Example of both:

func statusHandler(w http.ResponseWriter, r *http.Request) {
    v := mux.Vars(r)
    active, err := strconv.ParseBool(v["status"])
    // Handle err

    if active {
      // Do something
    } else {
      // Do something else


func statusHandler(w http.ResponseWriter, r *http.Request) {
    v := mux.Vars(r)

    switch v["status"] {
        case "0":
            // Do something
        case "1":
            // Do something else
            // Throw 500 Error
  • 写回答

1条回答 默认 最新

  • dongzhong7299 2017-11-28 13:59

    You could see the source code of ParseBool here. It uses switch too but with more cases. If the compiler inlines its code it, speed should be very similar to your code. If you want a definite answer you should benchmark different cases.

    In general I discourage you from paying attention to this small details. It's just matter of some nano seconds but it make your codes more difficult to understand. Begin optimizations with profiling your code to find hotspots that take a lot of time and fix them.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?



  • ¥15 CST仿真别人的模型结果仿真结果S参数完全不对
  • ¥15 误删注册表文件致win10无法开启
  • ¥15 请问在阿里云服务器中怎么利用数据库制作网站
  • ¥60 ESP32怎么烧录自启动程序
  • ¥50 html2canvas超出滚动条不显示
  • ¥15 java业务性能问题求解(sql,业务设计相关)
  • ¥15 52810 尾椎c三个a 写蓝牙地址
  • ¥15 elmos524.33 eeprom的读写问题
  • ¥15 用ADS设计一款的射频功率放大器
  • ¥15 怎么求交点连线的理论解?