您的位置:首页 > 编程语言 > C语言/C++

关于const char*和char*、const char** 和char** 赋值问题

2016-11-08 14:56 549 查看
我是在使用”io.h”中的_findfirst中遇到的问题:

问题描述:_findfirst返回的是long型; long _findfirst(const char , struct _finddata_t );查找成功返回句柄,否则返回-1,但是我想把文件路径传给该函数的时候,遇到的参数传递错误,一开始,我的实参为

const char* =”\*.“或者char =”\*.*”,但总是不对。

解决办法为:string dir=”\*.“,调用方法 long _findfirst(dir.c_str(), &file)。即定义路径为string类型,再把string转为char类型。

以下内容转自:

http://www.cnblogs.com/chenleiustc/archive/2011/04/09/2010647.html

根据ANSI C标准的赋值约束条件:

1. 两个操作数都是指向有限定符或无限定符的相容类型的指针。

2. 左边指针所指向的类型必须具有右边指针所指向类型的全部限定符。

一、const char*和char*

const char*的类型是:“指向一个具有const限定符的char类型的指针”。(不能修改其值)

char*的类型是:“指向一个char类型的指针”。

因此const char*和char*都是指向char类型的指针,只不过const char*指向的char类型是const的。

因此对于代码:

char* src;

const char* dest ;

dest = src;

这样赋值是正确的,因为:

* 操作数指向的都是char类型,因此是相容的

* 左操作数具有有操作数所指向类型的全部限定符(右操作数没有限定符),同时自己有限定符(const)

如果反过来赋值就违反了赋值的约束条件:src指向的对象的值可以修改,而dest指向的对象的值不可修改

如果让src去指向dest所指向的那个不可修改的对象,如果合法,岂不是变得可修改了?

src = dest; // 这样赋值,左操作数指向的类型没有右操作数指向类型的const限定符,不符合约束条件2

二、const char** 和char**

const char**的类型是:“指向一个有const限定符的char类型的指针的指针”。

char**的类型是:“指向一个char类型的指针的指针”。

对于const char** 和char**来说,二者都是没有限定符的指针类型,但是它们指向的类型不一样,前者指向char*, 而后者指向const char*,因此它们不相容,所以char**类型的操作数不能赋值给const char**类型的操作数。

即对于下列代码,编译器会报错:char** src;

const char** dest;

dest = src;

// error: invalid conversion from
char**' to
const char**’
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  c++ char指针
相关文章推荐