当前位置: 首页 > news >正文

C接口 中文字符问题

C接口 中文字符问题

  • 1. C接口字符串传递
  • 2. 示例代码
    • 2.1. 基本C接口字符传递(不支持中文)
    • 2.2. C接口中文字符传递(支持中文)

1. C接口字符串传递

在使用 C/C++ 编写 DLL 并通过 C# 调用时,常见的跨语言字符串传递方式是通过 const char*。但在涉及中文路径或文件名等含有非 ASCII 字符的情况时,如果编码方式处理不当,可能会出现乱码或崩溃问题。

本篇文章将详细讲解如何通过 const char* 实现 UTF-8 编码的中文字符传递,适配中英文路径,并在 C# 和 C++ 之间安全传参

主要问题汇总:

问题错误做法正确做法
中文乱码直接传 string / char*使用 UTF-8 编码 + 手动传递 IntPtr
编码不统一使用默认编码(如 ANSI)明确使用 UTF-8 编码
控制台乱码默认编码输出中文设置 SetConsoleOutputCP(CP_UTF8)

2. 示例代码

2.1. 基本C接口字符传递(不支持中文)

以char*作为字符串之间的传递

#define DLL_EXPORT __declspec(dllexport)
#define DLL_IMPORT __declspec(dllimport)extern "C" {
DLL_EXPORT int SetFile(const char* filePath) {std::cout << "filePath:" << filePath << std::endl;
}
} // extern "C"

2.2. C接口中文字符传递(支持中文)

为了支持中文字符,我们需要:

  • 保证 C# 传入的是 UTF-8 编码的字节流
  • 在 C++ 端以 UTF-8 的方式接收和处理
#define DLL_EXPORT __declspec(dllexport)
#define DLL_IMPORT __declspec(dllimport)extern "C" {
DLL_EXPORT int SetFile(const char* filePath) {std::string utf8_path(stpPath);std::cout << "filePath:" << utf8_path<< std::endl;
}
} // extern "C"

C#端调用示例

using System;
using System.Text;
using System.Runtime.InteropServices;class Program
{// 指定调用约定和 ANSI 编码,但我们传入的是 UTF-8 字节,所以用 IntPtr 更安全[DllImport("YourDll.dll", CallingConvention = CallingConvention.Cdecl)]public static extern int SetFile(IntPtr filePath);static void Main(){string filePath = "C:\\测试\\文件.txt";// 编码为 UTF-8 字节数组(带末尾 null 终止符)byte[] utf8Bytes = Encoding.UTF8.GetBytes(filePath + "\0");// 分配非托管内存IntPtr unmanagedPtr = Marshal.AllocHGlobal(utf8Bytes.Length);try{Marshal.Copy(utf8Bytes, 0, unmanagedPtr, utf8Bytes.Length);// 调用 C 接口SetFile(unmanagedPtr);}finally{Marshal.FreeHGlobal(unmanagedPtr); // 释放内存}}
}

✅ 说明:

  • 使用 Encoding.UTF8.GetBytes() 确保传入的是 UTF-8 编码。
  • 自行添加 \0 终止符,防止 C++ 接口访问越界。
  • 使用 IntPtr 而不是 string,避免编码转换的干扰。

相关文章:

  • 高端制造行业 VMware 替代案例合集:10+ 头部新能源、汽车、半导体制造商以国产虚拟化支持 MES、PLM 等核心应用系统
  • 极验叠字点选验证码识别
  • uni-app 提供的页面跳转方法详细解释及其区别
  • 模具制造业数字化转型:精密模塑,以数字之力铸就制造基石
  • 动态规划题解——爬楼梯(力扣70 easy)
  • LeetCode Hot100 (普通数组)
  • 解决 NestJS 中热重载与实体类自动导入不能兼容的问题
  • Ajax(Asynchronous JavaScript and XML)
  • 【连接器专题】 EIA-364 系列标准的完整列表
  • Vue之使用Vue-cli创建Webpack工程化项目
  • JavaScript 中对数组进行去重
  • craw4ai 抓取实时信息,与 mt4外行行情结合实时交易,基本面来觉得趋势方向,搞一个外汇交易策略
  • 每日Prompt:心中的佛
  • js 手写promise
  • 从解决一个分享图片生成的历史bug出发,详解LayoutInflater和View.post的工作原理
  • Golang | 搜索哨兵-对接分布式gRPC服务
  • 【Prompt Engineering】摸索出的一些小套路
  • 【mysql】-5 索引
  • C++智能指针用法及内存管理
  • Jenkins+Docker 实现一键自动化部署项目
  • 公司网站招聘板块怎么做/百度人工服务24小时热线电话
  • 顶尖手机网站建设/小网站关键词搜什么
  • wordpress新建页面连接无法访问/seo公司排名
  • 网站备案承诺书/网上的推广
  • 做电影网站什么系统好/seo代做
  • android网站开发实例/注册域名