-
2009-05-04
使用gethostbyname由域名或主机名得IP地址(转载)
使用这个东西,首先要包含2个头文件:
#include <netdb.h>
#include <sys/socket.h>struct hostent *gethostbyname(const char *name);
这个函数的传入值是域名或者主机名,例如"www.google.cn","wpc"等等。
传出值,是一个hostent的结构(如下)。如果函数调用失败,将返回NULL。struct hostent
{
char *h_name;
char **h_aliases;
int h_addrtype;
int h_length;
char **h_addr_list;
};
解释一下这个结构:
其中,
char *h_name 表示的是主机的规范名。例如www.google.com的规范名其实是www.l.google.com。
char **h_aliases 表示的是主机的别名.www.google.com就是google他自己的别名。有的时候,有的主机可能有好几个别名,这些,其实都是为了易于用户记忆而为自己的网站多取的名字。
int h_addrtype 表示的是主机ip地址的类型,到底是ipv4(AF_INET),还是pv6(AF_INET6)
int h_length 表示的是主机ip地址的长度
int **h_addr_lisst 表示的是主机的ip地址,注意,这个是以网络字节序存储的。千万不要直接用printf带%s参数来打这个东西,会有问题的哇。所以到真正需要打印出这个IP的话,需要调用inet_ntop()。const char *inet_ntop(int af, const void *src, char *dst, socklen_t cnt) :
这个函数,是将类型为af的网络地址结构src,转换成主机序的字符串形式,存放在长度为cnt的字符串中。
这个函数,其实就是返回指向dst的一个指针。如果函数调用错误,返回值是NULL。
下面是例程,有详细的注释。#include <netdb.h>
#include <sys/socket.h>int main(int argc, char **argv)
{
char *ptr,**pptr;
struct hostent *hptr;
char str[32];/* 取得命令后第一个参数,即要解析的域名或主机名 */
ptr = argv[1];/* 调用gethostbyname()。调用结果都存在hptr中 */
if((hptr = gethostbyname(ptr)) == NULL)
{
printf("gethostbyname error for host:%s\n", ptr);
return 0; /* 如果调用gethostbyname发生错误,返回1 */
}/* 将主机的规范名打出来 */
printf("official hostname:%s\n",hptr->h_name);/* 主机可能有多个别名,将所有别名分别打出来 */
for(pptr = hptr->h_aliases; *pptr != NULL; pptr++)
printf(" alias:%s\n",*pptr);/* 根据地址类型,将地址打出来 */
switch(hptr->h_addrtype)
{
case AF_INET:
case AF_INET6:
pptr=hptr->h_addr_list;/* 将刚才得到的所有地址都打出来。其中调用了inet_ntop()函数 */
for(;*pptr!=NULL;pptr++)
printf(" address:%s\n", inet_ntop(hptr->h_addrtype, *pptr, str, sizeof(str)));
break;
default:
printf("unknown address type\n");
break;
}return 0;
} -
2009-04-16
我不同意你说的话,但是我愿意誓死捍卫你说话的权利。 - [=>胡说八道]
From 伏尔泰
-
2009-04-16
跨越文明之火,远离宁静与温暖,在纯粹的黑暗中燃起一点光亮。 - [=>胡说八道]
嘘,安静~
我回来了
-
2009-02-26
关于DB2的锁
锁级别分类
行级
NS ?
NW ?
WE ?
表级
IN ?
IS
IX
SIX ?
Z ?
行或表级
S
U
X
锁的获取
通过Index Scan
有更新意图 IX on table --> S or X on rows
无更新意图 IS on table --> S on rows
通过Table Scan
有更新意图 X on table
无更新意图 S on table -
2009-02-25
DB2数据库索引概要 - [=>我的笔记]
本质:
索引的本质应该就是map,更具体的讨论 请看这里。借此,可以加速检索的速度。
在数据库表中创建索引可能有两个目的:
- 确保列值的唯一性
- 提高查询的性能
索引的种类:
- 唯一索引 (UNIQUE) 唯一索引用于保证唯一性,在创建主键时,会隐式地创建一个唯一索引
- 非唯一索引
- 降序/升序索引(DESC/AESC) 建立的索引都会按照一定顺序排序存储,可以显示地指定这个顺序。
- 双向索引 (ALLOW REVERSE SCAN ) 可以同时加速 MIN,MAX操作。
- 聚集索引 (CLUSTER) 建立聚集索引可以按照索引键顺序排序记录的物理存储(在以某种顺序检索数据时可提高性能)
p.s. 另外在索引中可以存储额外的列值(不必须为索引列),用以在检索数据时不必通过索引查询数据页,而直接取出结果。
总结
索引在加快检索的同时,会带来副作用(更慢的更新、插入和删除)。所以,应该根据需要使用索引:
- 对使用MAX操作的查询,用降序索引;MIN用升序索引;都有则用双向索引;
- select * from table where id > 100 and id < 200 针对这种查询聚集索引可以提高性能;
- select name from books where id > 100 and id < 200 如果大量检索,需要取出固定列的值,应使用包含列数据,避免访问数据页的开销
另外,总结几点与SQL有关的注意事项:
- 使用谓词like: like 'x%' 将会使用索引,而like '%x'将不能使用索引,而且因为谓词like的检索时间与字符串长度呈线性关系,使用VARCHAR代替CHAR可以去掉多余的空格,加快检索
- 使用 fetch first only 或 limit 限制结果集大小
参考
50种方法巧妙优化你的SQL Server数据库








