初めまして。css初心者なのですが、学習をしていく中で記法でわからない部分が出たのでご質問させていただきます。

例えばなのですが、

<p class="abc">こんにちは</p>

というHTMLに対し、

p[class="abc"] { color: blueviolet; }

p.abc { color: blueviolet; }

このどちらのcssも"こんにちは"という文字を紫色で表示してくれると思うのですが、この二つの記法に関して何か違いなどはあるのでしょうか?
「こっちを使用して書いた方が良い」や、「この二つの意味の違い」などがあれば教えていただけると幸いです。

よろしくお願いします。