本文详解如何在 Cgo 中为带 const char* 参数的 C 回调函数编写兼容的 Go 导出函数,解决因类型不匹配导致的编译错误,并提供安全、可移植的类型定义方案。 本文详解如何在 cgo 中为带 `const char*` 参数的 c 回调函数编写兼容的 go 导出函数,解决因类型不匹配导致的编译错误,并提供安全、可移植的类型定义方案。在使用 Cgo 调用 C 动态库或嵌入式 C 代码时,回调(callback)机制是常见需求。但当 C 头文件中回调签名包含 const char*(如 void (*cb)(const char*, int))时,直接在 Go 中用 *C.char 声明导出函数会导致编译失败------Cgo 自动生成的 _cgo_export.c 会将 Go 函数声明为 char*(非 const),与 C 原始声明冲突,触发"conflicting types"错误。根本原因在于:Cgo 不支持在 //export 函数签名中直接使用 const 限定符;*C.char 在 Cgo 类型系统中始终映射为 char*,而非 const char*。这不是 Go 的限制,而是 Cgo 类型桥接的设计约束。? 正确解决方案:通过 typedef 定义 const 兼容类型最简洁、标准且跨平台的方式是在 C 代码中定义一个带 const 的别名类型,并在 Go 中引用该类型:// 在 cgo 注释块内(或头文件中)/*typedef const char c_char_t;typedef void (*cb_func)(c_char_t*, int);void callback(cb_func cb);void myFunc(c_char_t*, int); // 注意:此处也需用 c_char_t**/import "C"对应 Go 导出函数需严格匹配该类型://export myFuncfunc myFunc(buf *C.c_char_t, ln C.int) { // 安全转换:C.GoStringN 接受 *C.char,但 *C.c_char_t 可隐式转为 *C.char // (因底层均为 char,const 仅是编译期约束) s := C.GoStringN((*C.char)(unsafe.Pointer(buf)), ln) fmt.Printf("Got: %s ", s)}完整可运行示例(main.go): 稿定AI 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能