
char* ,char[]
类似strtok分割的函数原型是char*strtok(char*strToken,constchar*strDelimit);例子charbuf[]=”GoldenGl...
类似strtok分割的函数
原型是 char *strtok( char *strToken, const char *strDelimit );
例子
char buf[]=”Golden Global View”;
char *ch = "b";
char* token = strtok( buf, ch);
这样是可以的,
那为什么 如果 buf 是这样的
char* buf =" Golden Global View“;
char *ch = "b";
char* token = strtok( buf, ch);
为什么第一个参数必须是数组呢,char [] 而直接的char* 却不可以呢,参数的类型也直接是char*的啊 展开
原型是 char *strtok( char *strToken, const char *strDelimit );
例子
char buf[]=”Golden Global View”;
char *ch = "b";
char* token = strtok( buf, ch);
这样是可以的,
那为什么 如果 buf 是这样的
char* buf =" Golden Global View“;
char *ch = "b";
char* token = strtok( buf, ch);
为什么第一个参数必须是数组呢,char [] 而直接的char* 却不可以呢,参数的类型也直接是char*的啊 展开
展开全部
你这个问题其实不是char*与char[]的关系,主要是strtok内部会去修改buf这个字符串,
你定义的char *buf = “Golden Global View”指向的是个常量,也就是说你传递的第一个参数实际上是 const char * buf型的,strtok在内部查找到b时,无法去修改原来的buf字符串的
你定义的char *buf = “Golden Global View”指向的是个常量,也就是说你传递的第一个参数实际上是 const char * buf型的,strtok在内部查找到b时,无法去修改原来的buf字符串的
展开全部
程序运行时,在内存中是分段的:有数据段,程序段,只读数据段等等。
1, char buf[]=”Golden Global View”; // 这个会把”Golden Global View”放在可读可写的数据段。
2, char* buf =" Golden Global View“; // 这个会把它放在 只读数据段,也就是说 buf是不可写的,所以任何对buf的写操作都是错误的。
1, char buf[]=”Golden Global View”; // 这个会把”Golden Global View”放在可读可写的数据段。
2, char* buf =" Golden Global View“; // 这个会把它放在 只读数据段,也就是说 buf是不可写的,所以任何对buf的写操作都是错误的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询