const typedef 和指针的问题(这里必须初始化的才初始化了,不必须的则没有初始化)

这里很容易搞混;

  • tyepdef  double dou;//这里是dou是double的别名
    

      

  • #include<iostream>
    
    using namespace std;
    
    int main()
    {
    	typedef char *pstring;	//pstring实际上是指向char的指针。
    
    	const pstring cstr = 0;	//cstr 是指向char 的常量指针
    	const pstring *ps;	//ps是一个指针,他的对象是指向char的常量指针
    
    	const char *str = 0;	//声明了一个指向const char 的指针
    	const int a = 0;
    	int const b = 0; //  上下一样的
    
    	//const直接修饰的变量必须初始化,但是像const int *c这种的不用初始化!!!!
    
    	// const 修饰的指针所指向的内存空间不准变 这个不用初始化
    
    	const int *c;   // c是一个指向常整形数的指针(所指向的内存数据不能被修改,但是本身可以修改)
    	int * const d = 0; // d 常指针(指针变量不能被修改,但是它所指向内存空间可以被修改)
    	const int * const e = 0; // e一个指向常整形的常指针(指针和它所指向的内存空间,均不能被修改)
    
    	system("pause");
    }
    

      

  • 其中
    const pstring cstr = 0;	//cstr 是指向char 的常量指针 pstring的类型为char * const
  • const int *c;   // c是一个指向常整形数的指针(所指向的内存数据不能被修改,但是本身可以修改)
时间: 2024-10-10 21:26:46

const typedef 和指针的问题(这里必须初始化的才初始化了,不必须的则没有初始化)的相关文章

C 中typedef 函数指针的使用

类型定义的语法可以归结为一句话:只要在变量定义前面加上typedef,就成了类型定义.这儿的原本应该是变量的东西,就成为了类型. int integer;     //整型变量int *pointer;   //整型指针变量int array [5]; //整型数组变量int *p_array [5]; //整型指针的数组的变量int (*array_pointer) [5];//整型数组的指针的变量int function (int param);//函数定义,也可将函数名看作函数的变量int

C语言基础知识----易让人头疼的关键字----const &amp;&amp; typedef &amp;&amp; define

const关键字 const=read only,修饰的为只读变量而不是常量.const修饰的变量不能用作数组的维数也不能放在switch语句的case:之后. 主要作用有: 1.通过把不希望被修改的变量或参数用const来修饰,编译器会保护这些变量不被修改增强系统的可靠性: 2.增强代码的可读性 [html] view plaincopyprint? const int a;      //a为常量不能被修改 int const a;      //a为常量不能被修改 const int *a

typedef 与指针、多维数组

1.在typedef中使用指针往往会带来意外的结果.如下: typedef string *pstring; const pstring cstr; 绝大数人刚开始都会认为cstr是一种指针,它指向const对象,即const pstring cstr 等价于const string *cstr,其实,这是不对的,错误的原因在于单纯地将typedef当做文本扩展了. 首先,我们要认识到pstring它是一个类型,表示的是指向string的指针.声明const pstring时,const修饰的是

const在修饰指针时的应用

用关键字const修饰一个指针时,根据其位置的不同有不同的含义. 例如: char str1[] = "Point to constant string"; const char *ptr = str1; 表示定义了一个指针ptr,它指向一个常数字符串.因此,运算 *ptr = 'Q'; 是非法的, 因为该字符串为常量. 但指针ptr本身为变量,可以修改.例如 ptr ++; 合法. 而 char str2[] = "A constant pointer"; cha

不可或缺 Windows Native (18) - C++: this 指针, 对象数组, 对象和指针, const 对象, const 指针和指向 const 对象的指针, const 对象的引用

[源码下载] 不可或缺 Windows Native (18) - C++: this 指针, 对象数组, 对象和指针, const 对象,  const 指针和指向 const 对象的指针, const 对象的引用 作者:webabcd 介绍不可或缺 Windows Native 之 C++ this 指针 对象数组 对象和指针 const 对象 const 指针和指向 const 对象的指针 const 对象的引用 示例1.CppEmployee 类CppEmployee.h #pragma

指向const对象的指针和const指针

const char *p1;/指向const对象的指针 char const *p2;//同上 char *const p3;//const 指针 区别:const后面是什么就限定什么,比如char const *p 就是限定(*p),(*p)就是p指向的那段内存不能变,p的值可以改变,如果是char* const p就是限定p指针的值. 1. 指向const对象的指针,适合做函数形参,保证指向对象不被修改 1.1 p1指向的值不可改变,指向const对象,但是p1可以被修改指向非const对

(转)const变量通过指针修改问题

程序笔试题-const变量通过指针修改问题 2012-10-06 20:45:18 分类: C/C++ const的变量在特定情况下可以通过指针修改,但是在另一些情况下是不能通过指针修改. 以下是VC6下才测试. 1 不能修改的情况 #include <stdio.h>int const a = 10;void main(void){ int *p = (int*)&a; *p = 20; printf("%d\n", *p);} 程序编译通过,但运行时错误: 指示

const关键字和指针的纠缠

const关键字定义的变量 #include<stdio.h>int  main( void ) {    const int a = 10;     a = 20; }12345671234567 结果怎样? 编译错误 [Error] assignment of read-only variable 'a' 变量a是只读的. 得到一个结论,使用const修饰的变量是常量,我们无法修改.在gcc中把const常量放到了data段,和全局变量一样,只是把它放到了一个区域中让我们无法修改,在运行过

typedef函数指针那些事

首先来介绍下函数指针: 函数指针是指向函数的指针变量,即本质是一个指针变量. int (*f) (int x); /* 声明一个函数指针 */ f=func; /* 将func函数的首地址赋给指针f */ 使用的时候可以直接通过(*f)(x)这样的形式.网上有很多的函数指针资料,就不多说了. 当我们在函数指针前加上typedef,就变成什么样了呢? 比如typedef  INT32  (*WNDPROC)(HWND, INT32, WPARAM, LPARAM); 这条语句的意思是定义了一个类型