Scroll to navigation

GETSOCKNAME(2) Руководство программиста Linux GETSOCKNAME(2)

ИМЯ

getsockname - получить имя сокета

ОБЗОР

#include <sys/socket.h>

int getsockname(int sockfd, struct sockaddr *addr, socklen_t *addrlen);

ОПИСАНИЕ

getsockname() возвращает текущий адрес, к которому привязан сокет sockfd, в буфере, указываемом addr. В параметре addrlen должно быть указано, сколько места выделено (в байтах), на которое указывает addr. При возврате в этом параметре передается реальный размер адреса сокета.

Возвращаемый адрес урежется, если предоставленный буфер окажется слишком маленьким; в этом случае в addrlen будет возвращено значение большее чем было в вызове.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении возвращается 0. В случае ошибки возвращается -1, а errno устанавливается в соответствующее значение.

ОШИБКИ

Аргумент sockfd не является допустимым дескриптором.
Аргумент addr указывает на память в недопустимой части адресуемого пространства процесса.
Неправильное значение аргумента addrlen (например, отрицательное).
Недостаточно ресурсов в системе для выполнения операции.
Аргумент sockfd является файлом, а не сокетом.

СООТВЕТСТВИЕ СТАНДАРТАМ

SVr4, 4.4BSD (вызов getsockname() появился в 4.2BSD), POSIX.1-2001.

ЗАМЕЧАНИЯ

Третий аргумент функции getsockname() в действительности имеет тип int * (это именно так в 4.x BSD, libc4 и libc5). Определенное недопонимание привело к тому, что в стандарте POSIX появился тип socklen_t также используемый в glibc. Смотрите также accept(2).

СМОТРИТЕ ТАКЖЕ

bind(2), socket(2), getifaddrs(3), ip(7), socket(7), unix(7)

2008-12-03 Linux