errno(come from baidu)

本文深入探讨了Linux中的errno错误代码及其在程序调试中的应用,详细列举了errno中常见的错误代码及其含义,帮助开发者更有效地进行错误排查。

errno

编辑本段NAME

  errno - number of last error
  errno 记录系统的最后一次错误代码。代码是一个int型的值,在errno.h中定义
  if (somecall() == -1) {
  printf("somecall() failed\n");
  if (errno == ...) { ... }
  }
  这样的例子并不能得到somecall这个函数的运行所产生的错误代码,因为很可能是printf这个函数产生的。
  if (somecall() == -1) {
  int errsv = errno;
  printf("somecall() failed\n");
  if (errsv == ...) { ... }
  这样才能真正得到运行somecall函数多带来的错误代码。
  }
   注意: 只有当一个库函数失败时,errno才会被设置。当函数成功运行时,errno的值不会被修改。这意味着我们不能通过测试errno的值来判断是否有错误存在。反之,只有当被调用的函数提示有错误发生时检查errno的值才有意义。
  查看错误代码errno是调试程序的一个重要方法。当linux C api函数发生异常时,一般会将errno变量(需include errno.h)赋一个整数值,不同的值表示不同的含义,可以通过查看该值推测出错的原因。在实际编程中用这一招解决了不少原本看来莫名其妙的问题。比较 麻烦的是每次都要去linux 源代码 里面查找错误代码的含义,现在把它贴出来,以后需要查时就来这里看了。

编辑本段errno的一些错误定义

  以下来自linux 2.4.20-18的内核代码中的/usr/include/asm/errno.h
  #ifndef _I386_ERRNO_H
  #define _I386_ERRNO_H
  #define EPERM 1 /* Operation not permitted */
  #define ENOENT 2 /* No such file or directory */
  #define ESRCH 3 /* No such process */
  #define EINTR 4 /* Interrupted system call */
  #define EIO 5 /* I/O error */
  #define ENXIO 6 /* No such device or address */
  #define E2BIG 7 /* Arg list too long */
  #define ENOEXEC 8 /* Exec format error */
  #define EBADF 9 /* Bad file number */
  #define ECHILD 10 /* No child processes */
  #define EAGAIN 11 /* Try again */
  #define ENOMEM 12 /* Out of memory */
  #define EACCES 13 /* Permission denied */
  #define EFAULT 14 /* Bad address */
  #define ENOTBLK 15 /* Block device required */
  #define EBUSY 16 /* Device or resource busy */
  #define EEXIST 17 /* File exists */
  #define EXDEV 18 /* Cross-device link */
  #define ENODEV 19 /* No such device */
  #define ENOTDIR 20 /* Not a directory */
  #define EISDIR 21 /* Is a directory */
  #define EINVAL 22 /* Invalid argument */
  #define ENFILE 23 /* File table overflow */
  #define EMFILE 24 /* Too many open files */
  #define ENOTTY 25 /* Not a typewriter */
  #define ETXTBSY 26 /* Text file busy */
  #define EFBIG 27 /* File too large */
  #define ENOSPC 28 /* No space left on device */
  #define ESPIPE 29 /* Illegal seek */
  #define EROFS 30 /* Read-only file system */
  #define EMLINK 31 /* Too many links */
  #define EPIPE 32 /* Broken pipe */
  #define EDOM 33 /* Math argument out of domain of func */
  #define ERANGE 34 /* Math result not representable */
  #define EDEADLK 35 /* Resource deadlock would occur */
  #define ENAMETOOLONG 36 /* File name too long */
  #define ENOLCK 37 /* No record locks available */
  #define ENOSYS 38 /* Function not implemented */
  #define ENOTEMPTY 39 /* Directory not empty */
  #define ELOOP 40 /* Too many symbolic links encountered */
  #define EWOULDBLOCK EAGAIN /* Operation would block */
  #define ENOMSG 42 /* No message of desired type */
  #define EIDRM 43 /* Identifier removed */
  #define ECHRNG 44 /* Channel number out of range */
  #define EL2NSYNC 45 /* Level 2 not synchronized */
  #define EL3HLT 46 /* Level 3 halted */
  #define EL3RST 47 /* Level 3 reset */
  #define ELNRNG 48 /* Link number out of range */
  #define EUNATCH 49 /* Protocol driver not attached */
  #define ENOCSI 50 /* No CSI structure available */
  #define EL2HLT 51 /* Level 2 halted */
  #define EBADE 52 /* Invalid exchange */
  #define EBADR 53 /* Invalid request descriptor */
  #define EXFULL 54 /* Exchange full */
  #define ENOANO 55 /* No anode */
  #define EBADRQC 56 /* Invalid request code */
  #define EBADSLT 57 /* Invalid slot */
  #define EDEADLOCK EDEADLK
  #define EBFONT 59 /* Bad font file format */
  #define ENOSTR 60 /* Device not a stream */
  #define ENODATA 61 /* No data available */
  #define ETIME 62 /* Timer expired */
  #define ENOSR 63 /* Out of streams resources */
  #define ENONET 64 /* Machine is not on the network */
  #define ENOPKG 65 /* Package not installed */
  #define EREMOTE 66 /* Object is remote */
  #define ENOLINK 67 /* Link has been severed */
  #define EADV 68 /* Advertise error */
  #define ESRMNT 69 /* Srmount error */
  #define ECOMM 70 /* Communication error on send */
  #define EPROTO 71 /* Protocol error */
  #define EMULTIHOP 72 /* Multihop attempted */
  #define EDOTDOT 73 /* RFS specific error */
  #define EBADMSG 74 /* Not a data message */
  #define EOVERFLOW 75 /* Value too large for defined data type */
  #define ENOTUNIQ 76 /* Name not unique on network */
  #define EBADFD 77 /* File descriptor in bad state */
  #define EREMCHG 78 /* Remote address changed */
  #define ELIBACC 79 /* Can not access a needed shared library */
  #define ELIBBAD 80 /* Accessing a corrupted shared library */
  #define ELIBSCN 81 /* .lib section in a.out corrupted */
  #define ELIBMAX 82 /* Attempting to link in too many shared libraries */
  #define ELIBEXEC 83 /* Cannot exec a shared library directly */
  #define EILSEQ 84 /* Illegal byte sequence */
  #define ERESTART 85 /* Interrupted system call should be restarted */
  #define ESTRPIPE 86 /* Streams pipe error */
  #define EUSERS 87 /* Too many users */
  #define ENOTSOCK 88 /* Socket operation on non-socket */
  #define EDESTADDRREQ 89 /* Destination address required */
  #define EMSGSIZE 90 /* Message too long */
  #define EPROTOTYPE 91 /* Protocol wrong type for socket */
  #define ENOPROTOOPT 92 /* Protocol not available */
  #define EPROTONOSUPPORT 93 /* Protocol not supported */
  #define ESOCKTNOSUPPORT 94 /* Socket type not supported */
  #define EOPNOTSUPP 95 /* Operation not supported on transport endpoint */
  #define EPFNOSUPPORT 96 /* Protocol family not supported */
  #define EAFNOSUPPORT 97 /* Address family not supported by protocol */
  #define EADDRINUSE 98 /* Address already in use */
  #define EADDRNOTAVAIL 99 /* Cannot assign requested address */
  #define ENETDOWN 100 /* Network is down */
  #define ENETUNREACH 101 /* Network is unreachable */
  #define ENETRESET 102 /* Network dropped connection because of reset */
  #define ECONNABORTED 103 /* Software caused connection abort */
  #define ECONNRESET 104 /* Connection reset by peer */
  #define ENOBUFS 105 /* No buffer space available */
  #define EISCONN 106 /* Transport endpoint is already connected */
  #define ENOTCONN 107 /* Transport endpoint is not connected */
  #define ESHUTDOWN 108 /* Cannot send after transport endpoint shutdown */
  #define ETOOMANYREFS 109 /* Too many references: cannot splice */
  #define ETIMEDOUT 110 /* Connection timed out */
  #define ECONNREFUSED 111 /* Connection refused */
  #define EHOSTDOWN 112 /* Host is down */
  #define EHOSTUNREACH 113 /* No route to host */
  #define EALREADY 114 /* Operation already in progress */
  #define EINPROGRESS 115 /* Operation now in progress */
  #define ESTALE 116 /* Stale NFS file handle */
  #define EUCLEAN 117 /* Structure needs cleaning */
  #define ENOTNAM 118 /* Not a XENIX named type file */
  #define ENAVAIL 119 /* No XENIX semaphores available */
  #define EISNAM 120 /* Is a named type file */
  #define EREMOTEIO 121 /* Remote I/O error */
  #define EDQUOT 122 /* Quota exceeded */
  #define ENOMEDIUM 123 /* No medium found */
  #define EMEDIUMTYPE 124 /* Wrong medium type */
  #endif
下载方式:https://pan.quark.cn/s/a4b39357ea24 布线问题(分支限界算法)是计算机科学和电子工程领域中一个广为人知的议题,它主要探讨如何在印刷电路板上定位两个节点间最短的连接路径。 在这一议题中,电路板被构建为一个包含 n×m 个方格的矩阵,每个方格能够被界定为可通行或不可通行,其核心任务是定位从初始点到最终点的最短路径。 分支限界算法是处理布线问题的一种常用策略。 该算法与回溯法有相似之处,但存在差异,分支限界法仅需获取满足约束条件的一个最优路径,并按照广度优先或最小成本优先的原则来探索解空间树。 树 T 被构建为子集树或排列树,在探索过程中,每个节点仅被赋予一次成为扩展节点的机会,且会一次性生成其全部子节点。 针对布线问题的解决,队列式分支限界法可以被采用。 从起始位置 a 出发,将其设定为首个扩展节点,并将与该扩展节点相邻且可通行的方格加入至活跃节点队列中,将这些方格标记为 1,即从起始方格 a 到这些方格的距离为 1。 随后,从活跃节点队列中提取队首节点作为下一个扩展节点,并将与当前扩展节点相邻且未标记的方格标记为 2,随后将这些方格存入活跃节点队列。 这一过程将持续进行,直至算法探测到目标方格 b 或活跃节点队列为空。 在实现上述算法时,必须定义一个类 Position 来表征电路板上方格的位置,其成员 row 和 col 分别指示方格所在的行和列。 在方格位置上,布线能够沿右、下、左、上四个方向展开。 这四个方向的移动分别被记为 0、1、2、3。 下述表格中,offset[i].row 和 offset[i].col(i=0,1,2,3)分别提供了沿这四个方向前进 1 步相对于当前方格的相对位移。 在 Java 编程语言中,可以使用二维数组...
源码来自:https://pan.quark.cn/s/a4b39357ea24 在VC++开发过程中,对话框(CDialog)作为典型的用户界面组件,承担着与用户进行信息交互的重要角色。 在VS2008SP1的开发环境中,常常需要满足为对话框配置个性化背景图片的需求,以此来优化用户的操作体验。 本案例将系统性地阐述在CDialog框架下如何达成这一功能。 首先,需要在资源设计工具中构建一个新的对话框资源。 具体操作是在Visual Studio平台中,进入资源视图(Resource View)界面,定位到对话框(Dialog)分支,通过右键选择“插入对话框”(Insert Dialog)选项。 完成对话框内控件的布局设计后,对对话框资源进行保存。 随后,将着手进行背景图片的载入工作。 通常有两种主要的技术路径:1. **运用位图控件(CStatic)**:在对话框界面中嵌入一个CStatic控件,并将其属性设置为BST_OWNERDRAW,从而具备自主控制绘制过程的权限。 在对话框的类定义中,需要重写OnPaint()函数,负责调用图片资源并借助CDC对象将其渲染到对话框表面。 此外,必须合理处理WM_CTLCOLORSTATIC消息,确保背景图片的展示不会受到其他界面元素的干扰。 ```cppvoid CMyDialog::OnPaint(){ CPaintDC dc(this); // 生成设备上下文对象 CBitmap bitmap; bitmap.LoadBitmap(IDC_BITMAP_BACKGROUND); // 获取背景图片资源 CDC memDC; memDC.CreateCompatibleDC(&dc); CBitmap* pOldBitmap = m...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值