杂碎小知识(持续更新)

1. %08lX

printf("%08lX \n", g_arList[i]);  表示16进制输出,08l其中‘08’表示输出宽度为8,内容在右边,左边补0,‘l’表示长整形

2. c++虚析构函数的作用

这样做是为了当用一个基类的指针删除一个派生类的对象时,派生类的析构函数会被调用。

3.关于unicode

char --->  wchar_t

" "   ----> L" "

4. sql语句里面的

select * from usersheet where loginname='sa' and userpass='sa' ;
在ado连接的时候写成
string StrSql="select * from usersheet where loginname='"+UserName+"' and userpass='"+PassWord +"'";
要注意的是,sql语句里面字符串通常用单引号括起来,sql语句是一个string对象,将各个部分+起来组成完整的语句。
断句如下,每个部分是一个string对象。
"select * from usersheet where loginname='"   +    UserName  +   "' and userpass='"     +    PassWord    +    "'";

5. c++的类型转换,可以将任意类型的指针转换为 void *, 0 可以转化为任意类型。
6. http://blog.csdn.net/haoel/article/details/1395358 c++开眼界了。最后一个例子如下,不可思议啊
  
  
  const int a = 1;
    int *p = const_cast<int*>(&a);
    *p = 2;
 
    cout << “value a=”<< a << endl;
    cout << “value *p=” <<*p << endl;
    cout << “address a=” <<&a << endl;
    cout << “address p=” <<p << endl;
这段代码输出的结果如下:
 
value a=1
value *p=2
address a=0xbff1d48c
address p=0xbff1d48c
 
地址都是一样的,可值为什么不一样呢?呵呵。这个问题看起来有点“学术味”过浓,不过是个好例子,可以让你知道 C++ 的一些用法和一些原理。有以下几个方面大家可以考虑一下:
1) const int a = 1 是不是和宏有点像,会不会被编译器优化了?
2) 去修改一个 const 的值,本来应该是不对的。这可能会是向旧的 C 兼容。是否会让编译器产生未知行为?
 
所以,这个示例也告诉我们,我们应该遵循 C++ 中的 const non-const 的语义,任何想要破坏这个语义的事情都会给我们带来未知的结果。
7. #undef FAR
#define FAR   far
而#define far
FAR 和 NEAR是16位的产物,在32的windef.h文件中,取消FAR的定义,并且将FAR重定义为far,而far实际上被定义为空,所以FAR为空。这是为了兼容以前的代码。

8. 在结构体中定义宏。
宏没有可见域,至于为什么在结构体里头#deifne,是因为这个宏一般用于定义该结构体里头的标志位变量的可能的值,和结构体的这个变量密切相关。放在一起从逻辑上比较容易理解。

9. 回调函数
回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,用于对该事件或条件进行响应。


10. 在函数参数里面有...表示可变参数列表。

11. 复制构造函数允许传值则会造成递归,导致栈溢出
class A {
private:
int value;
public:
A (int n) { value = n;}
A(A other) {value = other.value;}
};
int main()
{
 A a = 10;
A b = a;
}
a 在赋值给b时,需要复制。使用复制构造函数,这里是传值。在进入复制构造函数参数列表处,一直需要复制。导致递归。

10. 关于sscanf,对于字符串的提取不错。。

 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
/* sscanf example */
#include <stdio.h>

int main ()
{
  char sentence []="Rudolph is 12 years old";
  char str [20];
  int i;

  sscanf (sentence,"%s %*s %d",str,&i);
  printf ("%s -> %d\n",str,i);
  
  return 0;
}
Output:
Rudolph -> 12

11. sprintf
 
 
1
2
3
4
5
6
7
8
9
10
11
/* sprintf example */
#include <stdio.h>

int main ()
{
  char buffer [50];
  int n, a=5, b=3;
  n=sprintf (buffer, "%d plus %d is %d", a, b, a+b);
  printf ("[%s] is a string %d chars long\n",buffer,n);
  return 0;
}

Output:
[5 plus 3 is 8] is a string 13 chars long
vsprintf 用于实现可变参数,具体参见: http://blog.csdn.net/vsooda/article/details/9363373

12. #define 不能跨文件存在。
用论坛中的话说: 预处理过程是每个.cpp独立进行的。这些代码只有连接时才会连到一起。
所以一个文件中的define的东西不能在另一个文件中使用。。
vc中若要define一个多个文件共享的符号,可以在 工程 - 设置 - c/c++ - 常规 - 预处理程序定义 中 加入 自己想在多个文件中共享的符号
且vc中,若选择生成方式为debug,那么默认定义_DEBUG(定义的位置其实是一样的)。若生成方式为release 则_DEBUG没有定义。反之,是否release由NDEBUG指定。

13. linux一直需要使用一个文件夹,且文件夹比较深,可以使用快捷方式(软连接)
比如:ln -s /home/work/liushouda/platform/ myplatform
那么现在cd myplatform就可以搞定了。

14.  命令别名
vi ~/.bash_profile
比如ls -a 。可以在该文件最后加上   alias la='ls -a'
重新登录生效,以后用la就可以了。其他的命令类似

15. samba传文件很方便。scp可以给对方传文件。
 
16. int x = 53191; short y = x; int xy = y; printf("%d\n", xy); 
输出-12345。
因为 short的区间在于-32768至+32767。所以53191在编程了-12345.
说明了 int转short是取低位。
而 short转int,取的是值。而不是按位计算。(或者说保留了其符号)
17. unsigned int a = -1; printf("%d\n", a); 
输出为-1.所以即使你是unsigned。但是你的取值其实并不受影响。关键还是看解析方式。如果%u那么就会是-1了。 
 
18. short 转int
把short型数据赋值给int或者unsigned int型数据时,如果short型数据是负的,则扩展的比特位全是1,;如果short型数据是正的,则扩展的比特位全是0.
把unsigned short型数据赋值给int或者unsigned int型数据时,则扩展的比特位全是0

19. 注意:strlen 只对char有效。。其他类型的数组,请老实传入数组长度。
20.  php 获得数组下标的方法
foreach( $a as $key=>$value)
 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值