panic: runtime error问题分享

栏目: 数据库 · 发布时间: 7年前

内容简介:panic: runtime error: invalid memory address or nil pointer dereference关于这个错误问题panic: runtime error: invalid memory address or nil pointer dereference,我是如何解决的一般这个问题的出现,从提示上意思意思是无效的内存地址或空指针

panic: runtime error: invalid memory address or nil pointer dereference

关于这个错误问题panic: runtime error: invalid memory address or nil pointer dereference,我是如何解决的

一般这个问题的出现,从提示上意思意思是无效的内存地址或空指针

我遇到的问题是这样的我写了一个Session管理器,其中有一个函数是这样的

// SessionStart 启动Session功能
func (m *Manager) SessionStart(w http.ResponseWriter, r *http.Request) (session Session, err error) {
    m.lock.Lock()
    defer m.lock.Unlock()
    cookie, err := r.Cookie(m.cookieName)

    if err != nil || cookie.Value == "" {
        sid := m.GenerateSID()
        session, err = m.provider.SessionInit(sid)
        if err != nil {
            return nil, err
        }
        newCookie := http.Cookie{
            Name:     m.cookieName,
            Value:    url.QueryEscape(sid),
            Path:     "/",
            HttpOnly: true,
            MaxAge:   int(m.maxLifeTime),
        }
        http.SetCookie(w, &newCookie)
    } else {
        sid, _ := url.QueryUnescape(cookie.Value)
        session, _ = m.provider.SessionRead(sid)
    }

    return
}

然后我在使用的时候,是这样的

var appSession *session.Manager

// WelcomeLogin 欢迎登录页
func WelcomeLogin(w http.ResponseWriter, r *http.Request) {
    _, err := appSession.SessionStart(w, r)
    if err != nil {
        fmt.Println(err)
        return
    }

    cookie, err := r.Cookie("sessionid")
    if err != nil {
        fmt.Fprintf(w, "session")
    }

    fmt.Fprintf(w, cookie.Value)
}

func init() {
    appSession, _ := session.GetManager("memory", "sessionid", 3600)

    go appSession.SessionGC()
}

这段两端代码正常编译是没有任何问题,但是在调用WelcomeLogin的时候就报错了,因为WelcomeLogin函数调用了SessionStart,而SessionStart又调用了m.lock.Lock()。

这里注意m.lock.Lock()中的m,从错误提示上看是m的郭,问题在哪里呢,我通过记录日志的方式找到了原因,其实

appSession, _ := session.GetManager("memory", "sessionid", 3600)

这段代码和下面

appSession, _ = session.GetManager("memory", "sessionid", 3600)

这段代码是有很大区别的

使用第一段的时候

appSession得到的值是nil,而使用第二段的代码的时候就能正常赋值了。

这个问题在以后使用init进行操作变量重新赋值的时候一定要注意。为什么我能突然想到这个问题,因为我之前的几篇文章是写如何使用 MySQL 的,其中有个init中初始化的时候,重新赋值连接的变量涉及到这个问题,但是的做法就是直接赋值,并没有通过':='的方式赋值

// MySQLDB Conn
var MySQLDB *sql.DB

func init() {
    db, err := sql.Open("mysql", "root:123456@/wiki?charset=utf8")
    MySQLDB = db
    checkErr(err)
}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

后谷歌时代:大数据的衰落及区块链经济的崛起

后谷歌时代:大数据的衰落及区块链经济的崛起

乔治·吉尔德 / 现代出版社 / 2018-9-5 / 68

以大数据和机器智能为基础的谷歌时代(信息互联网时代)是一个令人敬畏的时代。但它即将终结。 《后谷歌时代》一书的作者乔治•吉尔德是一位颇具远见卓识的智者。他在技术和文化领域具有无与伦比的视野和见地。他向读者描述了谷歌所面临信任与安全危机,并勇敢地预测了即将到来的后谷歌时代。 谷歌用其惊人的“搜索和排序”能力吸引了整个世界。功能强大的搜索引擎,看似免费小应用,诸如视频、地图、电子邮箱等,让......一起来看看 《后谷歌时代:大数据的衰落及区块链经济的崛起》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具