我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linux C中sockaddr和sockaddr_in的区别

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linux C中sockaddr和sockaddr_in的区别

Linux C中sockaddr和sockaddr_in的区别

struct sockaddr和struct sockaddr_in这两个结构体用来处理网络通信的地址。

在各种系统调用或者函数中,只要和网络地址打交道,就得用到这两个结构体。

网络中的地址包含3个方面的属性:

1 地址类型: ipv4还是ipv6
2 ip地址
3 端口

相应的,头文件有如下定义:


include <netinet/in.h> 
 
struct sockaddr { 
  unsigned short  sa_family;  // 2 bytes address family, AF_xxx 
  char       sa_data[14];   // 14 bytes of protocol address 
}; 
 
// IPv4 AF_INET sockets: 
 
struct sockaddr_in { 
  short      sin_family;    // 2 bytes e.g. AF_INET, AF_INET6 
  unsigned short  sin_port;  // 2 bytes e.g. htons(3490) 
  struct in_addr  sin_addr;   // 4 bytes see struct in_addr, below 
  char       sin_zero[8];   // 8 bytes zero this if you want to 
}; 
 
struct in_addr { 
  unsigned long s_addr;     // 4 bytes load with inet_pton() 
}; 

注释中标明了属性的含义及其字节大小,这两个结构体一样大,都是16个字节,而且都有family属性,不同的是:

sockaddr用其余14个字节来表示sa_data,而sockaddr_in把14个字节拆分成sin_port, sin_addr和sin_zero分别表示端口、ip地址。sin_zero用来填充字节使sockaddr_in和sockaddr保持一样大小。

sockaddr和sockaddr_in包含的数据都是一样的,但他们在使用上有区别:

程序员不应操作sockaddr,sockaddr是给操作系统用的

程序员应使用sockaddr_in来表示地址,sockaddr_in区分了地址和端口,使用更方便。

一般的用法为:

程序员把类型、ip地址、端口填充sockaddr_in结构体,然后强制转换成sockaddr,作为参数传递给系统调用函数

网络编程中一段典型的代码为:


int sockfd; 
struct sockaddr_in servaddr; 
 
sockfd = Socket(AF_INET, SOCK_STREAM, 0); 
 
 
bzero(&servaddr, sizeof(servaddr)); 
servaddr.sin_family = AF_INET; 
servaddr.sin_port = htons(SERV_PORT); 
inet_pton(AF_INET, "127.0.0.1", &servaddr.sin_addr); 
 
 
connect(sockfd, (struct sockaddr *) &servaddr, sizeof(servaddr)); 
  



感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linux C中sockaddr和sockaddr_in的区别

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Linux C中sockaddr和sockaddr_in的区别

Linux C中sockaddr和sockaddr_in的区别 struct sockaddr和struct sockaddr_in这两个结构体用来处理网络通信的地址。在各种系统调用或者函数中,只要和网络地址打交道,就得用到这两个结构体。网
2022-06-04

Linux C中sockaddr和sockaddr_in的区别是什么

这篇文章给大家分享的是有关Linux C中sockaddr和sockaddr_in的区别是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Linux C中sockaddr和sockaddr_in的区别struc
2023-06-09

c++中::和.的区别

c++++ 中 :: 和 . 的区别回答:C++ 中的 :: 和 . 是两个不同的运算符,用于访问类成员和全局成员。详细解释:1. ::(范围解析运算符)用于访问全局成员,包括类外声明的变量、函数和类型。可以用来解决命名冲突,例如当
c++中::和.的区别
2024-04-26

c++中=和==的区别

c++ 中 = 和 == 的区别:"=" 是赋值运算符,将值赋给变量或引用;"==" 是相等操作符,比较两个值是否相等并返回布尔值。C++ 中 = 和 == 的区别C++ 中的 = 和 == 是两个不同的运算符,具有不同的功能和用途。=
c++中=和==的区别
2024-04-26

c++中|和||的区别

c++ 中 |(按位或)和 ||(逻辑或)之间的区别在于:1. 运算:| 进行逐位比较,而 || 进行逻辑比较。2. 优先级:|| 优先级高于 |。3. 用途:| 用于位掩码和移位运算,而 || 用于逻辑运算,如判断条件是否为真。C++ 中
c++中|和||的区别
2024-04-28

c++中::和:的区别

双冒号 (::) 用于命名空间作用域解析和类静态成员访问,单冒号 (:) 用于基类初始化和隐式类型转换。C++ 中 :: 和 : 的区别在 C++ 编程语言中,双冒号 (::) 和 单冒号 (:) 运算符具有不同的用法和含义。双冒号 (
c++中::和:的区别
2024-04-26

c++中+和++的区别

在 c++ 中,"+" 运算符用于数值相加和字符串连接,而 "++" 运算符则用于变量递增。"++" 可以作为后缀或前缀运算符使用,后缀递增在返回结果后再递增,而前缀递增在递增后再返回结果值。C++ 中 + 和 ++ 的区别在 C++ 中
c++中+和++的区别
2024-04-26

c++中==和=的区别

c++ 中,== 运算符用于比较表达式是否相等,返回布尔值(真或假);= 运算符用于赋值,将表达式的值分配给变量,返回被赋值的变量。C++ 中 == 和 = 的区别在 C++ 编程语言中,双等号 (==) 和单等号 (=) 运算符具有不同
c++中==和=的区别
2024-04-26

c和c++中static的区别

static 在 c 和 c++ 中的区别包括:作用域:c 中仅限于文件,c++ 可为文件或类作用域;链接:c 中仅链接到所在文件,c++ 中链接到整个程序;初始化:c 中默认为 0,c++ 中可初始化为任何值;函数:c 中仅限于声明文件,
c和c++中static的区别
2024-05-14

const在c和c++中的区别

在 c 和 c++ 中,const 关键字用于声明常量。在 c 中,const 只能修饰变量,不能修饰指针或数组;在 c++ 中,const 可以修饰变量、指针和数组。主要的差异在于:作用域、指针修改和初始化要求不同。const 在 C 和
const在c和c++中的区别
2024-04-28

static在c和c++中的区别

static关键字在c和c++中用于控制变量的生命周期和作用域。在c中,它延长局部变量和限制全局变量的作用域。在c++中,它还用于定义类成员变量和函数、命名空间中的变量和函数,以及函数内联。static在C和C++中的区别static是一
static在c和c++中的区别
2024-05-14

struct在c和c++中的区别

c和c++中struct的区别包括:c中成员默认公开访问,c++中默认私有访问。c++可以在struct定义中初始化成员,c中不允许。c++支持成员函数,c不支持。c++不支持匿名struct,c支持。c++可以使用宏控制struct内存对
struct在c和c++中的区别
2024-05-14

c++中void和int的区别

void和int在c++中的区别:void表示没有值的类型,用于不返回值的函数。int表示整型数字类型,用于存储和操作整数。void和int在C++中的区别C++中,void和int是两种不同的数据类型。1. voidvoid表示一个
c++中void和int的区别
2024-05-14

c语言中\和/的区别

c 语言中,反斜杠 '\' 用于转义特殊字符,而正斜杠 '/' 用于表示除法运算符。此外,反斜杠还可用于注释、分隔文件路径和拼接字符常量。C 语言中 \ 和 / 的区别直接回答:C 语言中,'\'(反斜杠)和 '/'(正斜杠)是两种不同的
c语言中\和/的区别
2024-04-28

c语言中=和==的区别

c语言中 "=" 赋值,而 "==" 比较。 "=" 将右边的值赋给左边的变量,而 "==" 比较两个表达式的值,相等返回真,否则返回假。C语言中 = 和 == 的区别C语言中的赋值运算符 "=" 和比较运算符 "==" 是两个不同的运算
c语言中=和==的区别
2024-05-02

c++中cin和scanf的区别

c++中,cin和scanf都是用于读取输入的函数。它们的主要区别在于:输入方式(cin使用运算符重载,scanf使用格式化字符串和指针)、数据类型(cin只支持特定类型,scanf支持多种类型)、错误处理(cin触发异常,scanf返回错
c++中cin和scanf的区别
2024-04-28

c语言中c和s的区别

"c" 和 "s" 是 c 语言的格式说明符,用于数据读写。"c" 针对单个字符,格式为 %c;"s" 针对以 '\0' 结尾的字符串,格式为 %s。C 和 S 在 C 语言中的区别"c" 和 "s" 在 C 语言中表示 格式说明符,用于
c语言中c和s的区别
2024-05-12

c++中string和char的区别

c++ 中 string 和 char 的区别:数据类型:string 是 stl 类,char 是基本数据类型。内存存储:string 使用动态内存分配,char 只分配一个字节。操作:string 支持多种操作,char 只支持有限的操
c++中string和char的区别
2024-05-09

c++中string和cstring的区别

在 c++ 中,string 和 cstring 是存储字符串的不同数据类型。string 使用动态内存管理和 unicode 编码,提供更高级的字符串操作和安全性。cstring 使用静态内存管理和 ascii 编码,对于简单的字符串操作
c++中string和cstring的区别
2024-05-10

c++中++i和i++的区别

在 c++ 中,递增运算符 ++i 和 i++ 的区别在于执行顺序:++i 先递增再计算表达式,而 i++ 先计算表达式再递增。因此,需要立即使用递增后的值时使用 ++i,需要先使用原始值再递增时使用 i++。C++ 中 ++i 和 i++
c++中++i和i++的区别
2024-04-26

编程热搜

目录