《C++ Primer》读书笔记(3.11,3.12,3.13,3.14)*

本文是《C++ Primer》的读书笔记,主要探讨了复数的概念及其表示,强调了const指针类型的正确理解,以及volatile修饰符在提示编译器处理对象变化时的作用,还介绍了std::pair类型用于组合不同或相同类型的值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

复数[complex number]

每个复数都有两部分 实数部分和虚数部分 虚数代表负数的平方根 这个术语是由笛卡儿首创的 复数的一般表示法如下 
        2 + 3i 

    复数对象的定义一般可以使用以下形式 

       #include <complex> 
	 // 纯虚数    0 + 7i 
        complex< double > purei( 0, 7 ); 

        // 虚数部分缺省为 0  3 + 0i 
        complex< float > real_num( 3 ); 

        // 实部和虚部均缺省为 0  0 + 0i 
        complex< long double > zero; 

typedef 名字 
typedef 机制为我们提供了一种通用的类型定义设施,可以用来为内置的或用户定义的数据类型引入助记符号 例如 
 typedef double wages; 
// double hourly, weekly; 
        wages hourly, weekly; 
并没有引入一种新的类型,而只是为现有类型引入了一个助记符号 typedef 名字对以出现在任何类型名能够出现的地方。 typedef 名字可以被用作程序文档的辅助说明,它也能够降低声明的复杂度

    下面是一个几乎所有人刚开始时都会答错的问题 错误在于将typedef 当作宏扩展 已知下面的typedef  

 typedef char *cstring;

在以下声明中 cstr 的类型是什么         extern const cstring cstr; 
    第一个回答差不多都是         const char *cstr 
    即指向const 字符的指针 但是 这是不正确的 const 修饰cstr 的类型 cstr 是一个指针 因此 这个定义声明了cstr 是一个指向字符的const 指针 见3.5 节关于const 指针类型的讨论 
        char *const cstr; 
还是没懂= =,mark


volatile 限定修饰符

volatile 修饰符的主要目的是提示编译器 该对象的值可能在编译器未监测到的情况下被改变,因此编译器不能武断地对引用这些对象的代码作优化处理 

        volatile int display_register; 
        volatile Task *curr_task; 
        volatile int ixa[ max_size ]; 
        volatile Screen bitmap_buf;
   display_register 是一个int 型的volatile 对象 curr_task 是一个指向volatile 的Task 类对象的指针 ixa 是一个volatile 的整型数组 数组的每个元素都被认为是volatile 的tmap_buf 
是一个volatile 的Screen 类对象 它的每个数据成员都被视为volatile 的


pair 类型  

pair 类也是标准库的一部分 它使得我们可以在单个对象内部把相同类型或不同类型的两个值关联起来

#include <utility> 
    pair< string, string > author( "James", "Joyce" );
可以用成员访问符号[member access notation]         访问pair 中的单个元素。它们的名字为firstsecond   例如 
        string firstBook; 

        if ( author.first == "James" && 
            author.second == "Joyce" ) 
             firstBook = "Stephen Hero";



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值