LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 766|回复: 4

新手请教问题

[复制链接]
发表于 2004-2-26 14:42:54 | 显示全部楼层 |阅读模式
想作个ip的比较程序
请问有没有存储字符串的数组?
php下随便建个数组,然后可以顺序放置以ip了,c下可以用什么来代替?

另外,暂时想通过把ip转为数字值,然后定义 int temp_ip[2000] 来存储,
但是数值范围又出问题了

[PHP]

#include <stdlib.h>
#include <stdio.h>

int main(int argc, char *argv[]) {
        int tmp_ip[100];
        int ip_now=255255255255;
        tmp_ip[0]=0;
        for(int i=0;i<3;i++){
        if(tmp_ip[0]==0){
                tmp_ip[0]=ip_now;
                printf("array is null\n");
        }
        else{
                printf("array isn't null ");
                if(tmp_ip[0]==255255255255){
                        printf("Ok\n");
                }
                printf("%12d \n",tmp_ip[0]);
        }
        }
        return 0;
}


[/PHP]

总是超了,请问用什么办法来解决下?
 楼主| 发表于 2004-2-26 17:50:02 | 显示全部楼层
现在用二维数组解决的,可执行起来慢了点啊,10w多条记录,统计完ip的来访次数,天都黑了
发表于 2004-2-26 20:05:51 | 显示全部楼层

  1. int ip_now=255255255255;
复制代码

这样写能不溢出吗?在32位的CPU上整数有多大?自己把0x7fffffff打印出来看看就知道了。如果是64位的CPU,可以另当别论。
看来楼主的基础知识真应该好好补补。
 楼主| 发表于 2004-2-27 10:00:39 | 显示全部楼层
那有没有什么别的办法解决一下?
发表于 2004-2-27 18:46:01 | 显示全部楼层
ip地址本身就是32位的,用unsigned int完全可以。
你就搞一个大数组,排一下序,查找起来应该非常快的
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表