在自动配置ODBC数据源时,SQLConfigDataSource的第四个参数需要传入一个字符串,字符串中包含了多个值,中间必须有"\0"分隔开,也就是说传入的字符串中间含有“\0”。直接使用字符串常量是没有问题的,但是一般的需求是不固定路径,也就是通过传入变量的方式来配置数据源。
比如说:char str=“DSN=MyAccess\0 DBQ=”+filePath;
乍一看没问题,其实你使用的时候你就会发现,\0表示结束,此时读取的str为:str=“DSN=MyAccess”+filePath; "\0 DBQ=“不见了。之后你会想到使用转义字符,char str=“DSN=MyAccess\\0 DBQ=”+filePath,你输出str,屏幕显示的确实是"DSN=MyAccess\0 DBQ=”+filePath,但是当你把str作为实参传入的时候,str又等于str=“DSN=MyAccess\0 DBQ=”+filePath,问题还没解决。
最后使用memcpy函数解决了这一问题。
memcpy(void *dest, void *src, unsigned int count);
功能:由src所指内存区域复制count个字节到dest所指内存区域。
char strcc[256] = “DSN=MyAccess\0 DBQ=”;//共18个字符,所以第一个参数+18
memcpy(strcc + 18, fileName, fileName.length());
此时的strcc中的字符串就含有\0。