Maison >Tutoriel système >Linux >Plusieurs concepts à comprendre dans la programmation en environnement Linux

Plusieurs concepts à comprendre dans la programmation en environnement Linux

WBOY
WBOYavant
2024-02-15 08:03:22664parcourir

Pour les débutants, s'ils souhaitent programmer dans un environnement Linux, ils doivent avoir une compréhension approfondie de certains concepts importants pour mieux écrire du code et implémenter des fonctions métier. Ci-dessous, nous présenterons plusieurs points de connaissances importants et couramment utilisés. La maîtrise de ces concepts peut éviter toute confusion lors du codage futur.

Plusieurs concepts à comprendre dans la programmation en environnement Linux

Appel système

«

Il existe certaines fonctions intégrées dans le noyau de tous les systèmes d'exploitation, qui peuvent être utilisées pour compléter certaines fonctions au niveau du système. Dans les systèmes Linux, ces fonctions sont appelées « appels système ». Ils représentent une transition de l'espace utilisateur à l'espace noyau.

Message reçu. Pour les débutants, si vous souhaitez programmer dans un environnement Linux, vous devez avoir une compréhension approfondie de certains concepts importants pour mieux écrire du code et implémenter des fonctions métier. Ci-dessous, nous présenterons plusieurs points de connaissances importants et couramment utilisés. La maîtrise de ces concepts peut éviter toute confusion lors du codage futur. ## Appel système > ❝ > > Il existe certaines fonctions intégrées dans le noyau de tous les systèmes d'exploitation, qui peuvent être utilisées pour exécuter certaines fonctions au niveau du système. Dans les systèmes Linux, ces fonctions sont appelées « appels système » (appel système). ) . Ils représentent une transformation de l'espace utilisateur vers l'espace noyau > > ❞

.

4 sur 5

J'aime ou je n'aime pas plus

  • Les appels système sont des services fournis par le système d'exploitation Linux et constituent l'interface d'écriture des communications entre les applications et le noyau, ce que nous appelons des fonctions. Par rapport aux appels de fonction ordinaires, la consommation de performances des appels système est relativement importante. Par conséquent, pendant que le programme recherche les performances, essayez d'éviter les appels système.
  • Les programmes en mode utilisateur transmettent les paramètres via la pile par défaut. Pour les appels système, le mode noyau et le mode utilisateur utilisent des piles différentes, ce qui fait que les paramètres d'appel système ne passent que par les registres.

Opération IO

«

Qu'est-ce que IO ? En termes simples, cela signifie entrée et sortie

  • IO est divisé en IO standard et IO de fichier. Nos scanf, printf, getchar, putchar, gets, puts couramment utilisés sont tous des entrées et sorties standard. Sous le système Linux, tout est un fichier, il existe donc deux types d'opérations d'E/S sur fichier : les E/S standard et les E/S sur fichier en programmation sous Linux. Les E/S standard sont des E/S mises en mémoire tampon et appartiennent aux fonctions de bibliothèque, tandis que les E/S de fichier ne sont pas mises en tampon et appartiennent aux appels système.

E/S standard :

1.标准IO是由ANSIC标准定义

2.跨平台,可以在windows下运行,也可以在Linux下运行

3.通过缓冲机制来减少系统调用,实现更高的效率

4.文件流 标准IO用结构体类型来存放文件的相关信息,标准IO所有操作围绕着FILE来操作。

Fichier IO :

1.文件IO是POSIX提供的一组函数

2.只能运行在可移植操作系统中,不能跨平台

3.没有缓冲机制

4.文件描述符是一个非负整数,每打开一个文件,系统会自动分配一个文件描述符(即从系统最小的且没有被用的描述符来分配)

原子操作

原子在化学课程中是不可再分的颗粒。而对于Linux系统来说所谓原子操作是为了确保对一个整型数据的更改具有排他性。原子操作就是要么不执行,一旦执行就会执行完成,是不可被打断的一个,或一系列的动作,即在完成任务前不会被其他事件所打断,就像原子不可被分割成颗粒一样。单处理中,可以用单条指令完成的指令可以被看成是一个原子操作。软件中的原子操作依赖于硬件原子操作的支持。当然原子操作,也可以当引用计数使用。

  • 原子操作其实本质上和锁实现同样的功能,都是为了保护共享对象,它具有原子性,和顺序性。原子性确保指令执行期间不被打断,要么全部执行,要么根本不执行。而顺序性确保即使两条或多条指令出现在独立的执行线程中,甚至独立的处理器上,它们本该执行的顺序依然要保持。

线程安全

所谓线程安全,就是指代码可以在多线程环境下安全地执行,输出我们想要的结果。即符合正确的逻辑,是程序员期望的正常执行结果。为了实现线程安全,Linux系统提供一些列的方法,或者只能使用局部变量或资源,或者就是利用锁等同步机制,来实现全局变量或资源的访问。

  • 线程安全在Linux环境编程中极其重要,我们不仅要了解概念,更重要的是要在实际的编程中学会实现线程安全方式。下面来看一个简单的例子:
#include 
#include 
#include 

static int nCnt = 0;

void * Thread(void * arg)
{
    for (int i = 0; i return NULL;
}
int main()
{
    pthread_t t1;
    pthread_t t2;

    /* 创建两个线程 */
    pthread_create(&t1, NULL, thread, NULL);
    pthread_create(&t2, NULL, thread, NULL);

    pthread_join(t1, NULL);
    pthread_join(t2, NULL);

    printf("nCnt is %d by threads\n", nCnt);

    return 0;
}
  • 大家看出上面例子的问题了吗?
  • 对,没错,在此例子中我们创建了两个线程,线程函数是同一个函数,在线程函数中是对全局变量nCnt的自增操作。这个例子中输出结果和我们想要的是不一样,就是因为nCnt执行指令并不是原子的,两个个线程对nCnt的并发访问出现了问题。我们利用锁就可以解决此问题。

阻塞与非阻塞

Linux环境编程中的阻塞与非阻塞,都是指I/O操作。而所有的I/O系统调用默认都是阻塞的。那什么是阻塞? 阻塞的系统调用是指当进行系统调用时除非出错或被信号打断,那么系统调用将会一直陷入内核态直到调用完成。非阻塞的系统调用是指无论I/O操作成功与否,调用都会立刻返回。阻塞和非阻塞IO是访问设备的两种模式,驱动程序可以灵活的支持这两种用户空间对设备的访问方式。

  • 阻塞操作是指在执行操作时,若不能获得资源,则阻塞进程直到满足条件再进行操作。被阻塞的进程进入睡眠状态,被调度器的运行队列移走,直到等待的条件满足
  • 非阻塞是指在进行操作时,若不能获得资源,他要么放弃,要么返回后重新查询,直到可以进行操作为止。
  • 当数据准备好时二者的模式相同,即IO操作都是将进程阻塞,直到IO操作完成
  • 阻塞、非阻塞是设备文件、网络文件的属性

同步与异步

同步与异步,也是指I/O操作。POSIX定义如下:A synchronous I/O operation causes the requesting process to beblocked until that I/O operation completes An asynchronous I/O operation does not cause the requesting processto be blocked

  • La différence entre les deux est que les E/S synchrones ne bloquent pas le processusIO操作时会将进程阻塞,而异步IO做IO操作
  • Lorsque les éléments bloquants, non bloquants, synchrones et asynchrones sont réunis, une confusion surgit inévitablement. La synchronisation signifie-t-elle bloquer et asynchrone signifie-t-il non-blocage ? En fait, dans les opérations d’E/S, ce sont des concepts différents. La synchronisation peut être bloquante ou non bloquante, et les appels d'E/S Linux couramment utilisés sont en réalité synchrones. La synchronisation et l'asynchronisme font ici référence au fait que la copie des données d'E/S soit exécutée de manière synchrone.
  • Prenons l'appel système read comme exemple. La lecture bloquante restera dans l'état du noyau jusqu'au retour de la lecture ; la lecture non bloquante reviendra directement lorsque les données ne sont pas prêtes, et lorsqu'il y a des données, la lecture non bloquante restera également dans l'état du noyau jusqu'à ce que la lecture soit complété. Cette lecture est une opération synchrone, c'est-à-dire que l'achèvement des E/S est effectué de manière synchrone dans le cadre du processus d'exécution en cours. Si elle est asynchrone, l'opération d'E/S ne se termine pas de manière synchrone avec l'appel système. Après le retour de l'appel, l'opération d'E/S n'est pas terminée. Au lieu de cela, le système d'exploitation ou un certain thread est responsable de l'opération d'E/S réelle, et le thread d'origine est notifié une fois terminé
  • .

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer