Go 语言没有传统意义上的类(class),但通过结构体(struct)和方法(method)可以自然地实现面向对象编程的核心思想:封装、组合与行为绑定。关键在于理解 方法是绑定到特定类型的函数,而结构体就是最常用、最直观的自定义类型载体。
pointer
精选推荐
最新动态
Golang 结构体与方法:面向对象编程入门与自定义类型
如何在Golang中安全地使用unsafe包进行指针类型转换_最佳实践
unsafe 包本身不提供“安全”的指针转换——它绕过 Go 类型系统,所谓“安全”只取决于你是否严格遵守内存布局、生命周期和对齐约束。
CSS项目实战之FAQ手风琴效果_纯CSS实现内容展开收起
因为默认样式太难看,且老浏览器不支持。Chrome 12+、Firefox 49+、Safari 6.2+ 支持,Edge 79+ 也行;IE 全系不支持。如果你的项目要兼容 IE 或旧安卓 WebView,就得换方案。
CSS轮廓线设置_outline与border的区别及应用
这是最常被误用的根源。当你给一个 div 加上 outline: 2px solid red,它不会影响周围元素的位置;但换成 border: 2px solid red,整个盒模型宽度和高度就多了 4px(上下/左右各 2px),可能触发重排或挤掉邻近元素。
CSS文本下划线滑动过渡_利用伪元素与width实现的特效
根本原因是 ::after 初始状态没设透明或隐藏,浏览器渲染时先画出默认宽度的下划线,再缩放/位移——人眼就看到“闪”。必须让伪元素初始不可见,且用 transform 配合 transition 控制变化路径。
Golang单例模式防止反射破坏_保护对象实例的唯一性
Go 的单例靠包级变量 + 私有构造函数“约定俗成”,但 reflect 能绕过导出性检查,直接调用未导出的构造函数或复制结构体字段。一旦有人用 reflect.New() + reflect.Value.Elem().Set() 或 reflect.ValueOf(&instance).Elem().Interface() 二次实例化,单例就失效了。
Golang中对一个未初始化的指针变量解引用会发生什么_运行时Panic
Go 运行时检测到对 nil 指针的解引用(即用 * 操作符读/写),会立即中止当前 goroutine 并抛出 panic。这不是编译错误,而是在运行期确定的——只要那行代码被执行,就一定崩。
如何在Golang中初始化一个nil切片与空切片_nil vs []T{}
不等价。它们长度和容量都是 0,但底层指针状态不同:nil 切片的底层数组指针为 nil,而 []T{} 的底层数组指针非 nil(指向一个零长数组)。这会影响序列化、比较、反射行为,也常在 JSON 解析或接口断言时暴露问题。
如何在Golang中避免指针的空值引用_Golang指针空值检查与安全实践
Go 语言里对 nil 指针取值(比如 *p)或调用方法,会立即触发运行时 panic:panic: runtime error: invalid memory address or nil pointer dereference。这不是编译错误,而是在运行时崩溃——所以空指针检查不是“可选优化”,而是必须的防御动作。
CSS禁止文本选中_user-select属性的安全保护作用
它只是告诉浏览器“别让鼠标选中这段文字”,对开发者工具、网络请求、DOM 操作完全无效。真实世界里,只要页面渲染完成,任何文本都能被脚本读取、复制、截图、抓包。