Let's say:
xb@dnxb:/tmp$ echo 'ls -l /proc/$$/fd | grep a.sh' > a.sh; \
> while IFS='' read -r f; do \
> echo "$f"; "$f" a.sh; \
> done < <(tail -n +2 /etc/shells)
/bin/sh
lr-x------ 1 xiaobai xiaobai 64 Jan  20 00:09 10 -> /tmp/a.sh
/bin/dash
lr-x------ 1 xiaobai xiaobai 64 Jan  20 00:09 10 -> /tmp/a.sh
/bin/bash
lr-x------ 1 xiaobai xiaobai 64 Jan  20 00:09 255 -> /tmp/a.sh
/bin/rbash
lr-x------ 1 xiaobai xiaobai 64 Jan  20 00:09 255 -> /tmp/a.sh
/bin/zsh
lr-x------ 1 xiaobai xiaobai 64 Jan  20 00:09 11 -> /tmp/a.sh
/usr/bin/zsh
lr-x------ 1 xiaobai xiaobai 64 Jan  20 00:09 11 -> /tmp/a.sh
/bin/ksh93
lr-x------ 1 xiaobai xiaobai 64 Jan  20 00:09 10 -> /tmp/a.sh
/bin/rksh93
lr-x------ 1 xiaobai xiaobai 64 Jan  20 00:09 10 -> /tmp/a.sh
xb@dnxb:/tmp$ 
Does bash always has fixed fd number 255 and zsh has fixed fd number 11 by default ?
I ask this question because I need to extract the full path executed from any shell processes. I wonder I can hard-coded my script to refer this fixed numbers or not.
Note that this is for personal script and not means to run on critical business, so I'm not looking for 100% reliable, but does the fd number fixed on most of the cases ?
[UPDATE]:
The reason why I don't parse the cmdline is because:
xb@dnxb:~/Downloads$ cat foo.sh 
#!/bin/bash
cat "/proc/$$/cmdline" | tr '\0' '\n'
readlink -f /proc/$$/fd/255
xb@dnxb:~/Downloads$ bash --norc foo.sh --norc
bash
--norc
foo.sh
--norc
/home/xiaobai/Downloads/foo.sh
xb@dnxb:~/Downloads$ 
As you can see, only fd able to give the full path /home/xiaobai/Downloads/foo.sh, but not the cmdline. And the script can't distinguish either foo.sh or --norc is a path or an option since foo.sh can appear at any option position, unless I do ugly checking such as it's not startswith --. 
While fd has no problem to produces the correct full path even I do bash --norc foo.sh --norc foo2.sh.
Anyway, I just realized my task don't have to check this since I noticed no system processes except custom process are inherited from shell. But still any answer will help to future reader.



/proc/<pid>/cmdline?