c++的一些特殊情况

1   *(p++)表示*p之后再p++,也能写成*p++;经过测试*++p和*(++p)也都能正常通过编译得到正确结果。

2 char类型的数据实际上是ascii码,共8bit,即可以直接用于数组的索引,比如char a='a';int s[256]; s[a]表示s[97],因为'a'的ascii吗是97,这里注意8bit可以表示256个ascii码,但实际ascii码只有0~127是有效的。即s数组可以声明为s[128]即可。

3  qsort对字符串数组(每个字符串都是char *或者char[]类型,而不是string)排序时,

编写compar函数比较字符串有地方要注意:

不能把strcmp本身传给qsort,即不能写strcmp(p,q),因为形参是const void*类型,同理,写成strcmp((char *)p, (char *)q)也是无效的(但是当字符串数组是char[]类型时,这个可以正常运行);最正确的写法应该是:strcmp(*(char **)p, *(char **)q);先强制转换成char**,在用*减少一层间接寻址操作:

int compar_words(const void *p, const void *q)

{

       return strcmp(*(char **)p, *(char **)q);

}

4 typedef除了诸如:typedef int INT;之类的取别名,还可以为某些复杂的类型取一个简单的别名,别如:typedef int (*p[2])(int); p func={func1,func2};,此时typedef定义了一个函数指针的数组,有两个元素,然后初始化这两个元素分别为指向func1和func2的指针。当然上面的例子中也可以typedef int(*p)(int); p func[2]={func1,func2};

5 template可以传常量而不是类型,但是只能是int的常量,或者其他类型的引用或者指针。比如template <typename T,int a>func()。类型可以有默认值,但是类型的形参不能指定默认值,比如template<T=int>func;但是不可以template<T a=10>func;因为你都不知道a是什么类型,当然不能指定形参的值了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值