Pcap nsock sockets in NSE were cached so that multiple threads opening the "same" pcap descriptor (same device, bpf, promisc, snaplen) would get the same socket object. This is a leftover from a very old design that would multiplex captured packets to each thread, but for a long time that meant that each thread would just get whatever packets were available and miss any that another thread received. This almost never happened because scripts don't use identical pcap descriptors generally. But it did complicate garbage collection, resulting in segfaults and assertion failures in certain scenarios such as double-closing a socket.
Nmap

Nmap is released under a custom license, which is based on (but not compatible with) GPLv2. The Nmap license allows free usage by end users, and we also offer a commercial license for companies that wish to redistribute Nmap technology with their products. See Nmap Copyright and Licensing for full details.
The latest version of this software as well as binary installers for Windows, macOS, and Linux (RPM) are available from Nmap.org
Full documentation is also available on the Nmap.org website.
Questions and suggestions may be sent to the Nmap-dev mailing list.
Installing
Ideally, you should be able to just type:
./configure
make
make install
For far more in-depth compilation, installation, and removal notes, read the Nmap Install Guide on Nmap.org.
Using Nmap
Nmap has a lot of features, but getting started is as easy as running nmap scanme.nmap.org. Running nmap without any parameters will give a helpful
list of the most common options, which are discussed in depth in the man
page. Users who prefer a graphical interface
can use the included Zenmap front-end.
Contributing
Information about filing bug reports and contributing to the Nmap project can be found in the HACKING and CONTRIBUTING.md files.