linux编程 段错误 (核心已转储)

linux编程 段错误 (核心已转储),第1张

#include"stdio.h"

#include"stdlib.h"

#define NMEMB 50

#define SIZE 10

#include <string.h>

int compar (const void *a,const void *b)

{

return (strcmp((char *) a, (char *) b))

}

int main()

{

  char data[NMEMB][SIZE]={"Linux","freebsd","solzris","sunos","windows"}

  char key[80],*base,*offset

  int nmemb= 5,size=SIZE

  

  fgets(key,sizeof(key)/sizeof(key[0]),stdin)

  key[strlen(key)-1]='\0'

  

  base = data[0]

  offset = (char *)bsearch(key,base,nmemb,size,compar)

  if(offset ==NULL)

    {

    printf("%s not found!\n",key)

    }

  else

    {

    printf("found : %s \n",offset)

    }

}

在的所在.c文件的目录中

在终端里面敲

1. ulimit -c unlimited

2. 在用gcc编译时,在最后加上-g

3. 运行一次错误代码,出现段错误后, 目录中有一个core文件

4. 运行:gdb ./a.out core

会自动帮你找出可能出错的代码,出现段错误一般都是越界了

/*************************************

文件名: server.c

linux 下socket网络编程简例 - 服务端程序

服务器端口设为 0x8888 (端口和地址可根据实际情况更改,或者使用参数传入)

服务器地址设为 192.168.1.104

作者:kikilizhm#163.com (将#换为@)

*/

#include <stdlib.h>

#include <sys/types.h>

#include <stdio.h>

#include <sys/socket.h>

#include <linux/in.h>

#include <string.h>

int main()

{

int sfp,nfp/* 定义两个描述符 */

struct sockaddr_in s_add,c_add

int sin_size

unsigned short portnum=0x8888/* 服务端使用端口 */

printf("Hello,welcome to my server !\r\n")

sfp = socket(AF_INET, SOCK_STREAM, 0)

if(-1 == sfp)

{

printf("socket fail ! \r\n")

return -1

}

printf("socket ok !\r\n")

/* 填充服务器端口地址信息,以便下面使用此地址和端口监听 */

bzero(&s_add,sizeof(struct sockaddr_in))

s_add.sin_family=AF_INET

s_add.sin_addr.s_addr=htonl(INADDR_ANY)/* 这里地址使用全0,即所有 */

s_add.sin_port=htons(portnum)

/* 使用bind进行绑定端口 */

if(-1 == bind(sfp,(struct sockaddr *)(&s_add), sizeof(struct sockaddr)))

{

printf("bind fail !\r\n")

return -1

}

printf("bind ok !\r\n")

/* 开始监听相应的端口 */

if(-1 == listen(sfp,5))

{

printf("listen fail !\r\n")

return -1

}

printf("listen ok\r\n")

char gc

while(1)

{

sin_size = sizeof(struct sockaddr_in)

/* accept服务端使用函数,调用时即进入阻塞状态,等待用户进行连接,在没有客户端进行连接时,程序停止在此处,

不会看到后面的打印,当有客户端进行连接时,程序马上执行一次,然后再次循环到此处继续等待。

此处accept的第二个参数用于获取客户端的端口和地址信息。

*/

nfp = accept(sfp, (struct sockaddr *)(&c_add), &sin_size)

if(-1 == nfp)

{

printf("accept fail !\r\n")

return -1

}

printf("accept ok!\r\nServer start get connect from %#x : %#x\r\n",ntohl(c_add.sin_addr.s_addr),ntohs(c_add.sin_port))

/* 这里使用write向客户端发送信息,也可以尝试使用其他函数实现 */

if(-1 == write(nfp,"hello,welcome to my server \r\n",32))

{

printf("write fail!\r\n")

return -1

}

while((gc = getchar()) != EOF) /* 按ctrl + z 键结束,或者给定一个特殊字符,如'#',即 hile((gc = getchar()) != '#') */

{

write(nfp,gc,1)

}

printf("write ok!\r\n")

close(nfp)

}

close(sfp)

return 0

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/8719793.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-20
下一篇2023-04-20

发表评论

登录后才能评论

评论列表(0条)

    保存